diff src/aci2/mfw/mfw_sim.~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
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/aci2/mfw/mfw_sim.~c	Mon Sep 26 00:29:36 2016 +0000
@@ -0,0 +1,2946 @@
+/*
++--------------------------------------------------------------------+
+| PROJECT: MMI-Framework (8417)         $Workfile:: mfw_sim.c       $|
+| $Author:: Vo                          $Revision::  1              $|
+| CREATED: 13.10.98                     $Modtime:: 22.03.00 17:21   $|
+| STATE  : code                                                      |
++--------------------------------------------------------------------+
+
+   MODULE  : MFW_SIM
+
+   PURPOSE : This modul contains the functions for SIM management.
+
+
+   $History:: mfw_sim.c                                              $
+ *
+ * *****************  Version 43  *****************
+ * User: Vo           Date: 22.03.00   Time: 17:29
+ * Updated in $/GSM/Condat/MS/SRC/MFW
+ * Add new parameter PIN type in structure T_MFW_SIM_STATUS to
+ * identify PIN type
+ * Change in SIM lock
+ *
+ * *****************  Version 42  *****************
+ * User: Es           Date: 2.03.00    Time: 16:18
+ * Updated in $/GSM/Condat/MS/SRC/MFW
+ * use 'aci_delete()' instead of 'aci_ext_init()' to clear the
+ * primitive routing for mfw_sim. (because other routings may have to
+ * be preserved!)
+ *
+ * *****************  Version 41  *****************
+ * User: Vo           Date: 22.12.99   Time: 16:03
+ * Updated in $/GSM/Condat/MS/SRC/MFW
+ * Remove maximum preferred PLMN records and used preferred PLMN
+ * records in local memory
+ *
+ * *****************  Version 40  *****************
+ * User: Vo           Date: 2.12.99    Time: 13:18
+ * Updated in $/GSM/Condat/MS/SRC/MFW
+ * New: request of max/used perferred PLMN list
+ *
+ * *****************  Version 39  *****************
+ * User: Vo           Date: 17.11.99   Time: 11:37
+ * Updated in $/GSM/Condat/MS/SRC/MFW
+ * Bug fix: de-personalisation for SIM lock
+ * New: SIM inserted
+ *
+ * *****************  Version 38  *****************
+ * User: Vo           Date: 21.10.99   Time: 13:26
+ * Updated in $/GSM/Condat/MS/SRC/MFW
+ * add response of de-registration
+|
+| *****************  Version 37  *****************
+| User: Le           Date: 11.10.99   Time: 16:27
+| Updated in $/GSM/Condat/MS/SRC/MFW
+|
+| *****************  Version 36  *****************
+| User: Le           Date: 8.10.99    Time: 13:38
+| Updated in $/GSM/Condat/MS/SRC/MFW
+|
+| *****************  Version 35  *****************
+| User: Le           Date: 4.10.99    Time: 10:33
+| Updated in $/GSM/Condat/MS/SRC/MFW
+ *
+ * *****************  Version 34  *****************
+ * User: Es           Date: 29.09.99   Time: 11:20
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * including CFUN_OK enhancement by AK, not fully implemented
+ *
+ * *****************  Version 33  *****************
+ * User: Es           Date: 16.09.99   Time: 16:56
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * reordered include statements due to addons in mfw_phb.h
+ *
+ * *****************  Version 32  *****************
+ * User: Vo           Date: 13.09.99   Time: 12:05
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * change comment
+ *
+ * *****************  Version 31  *****************
+ * User: Vo           Date: 12.09.99   Time: 15:32
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * Bug fix: change PIN
+ * Bug fix/New: SIM lock
+ * New: request of PIN status
+ * New: save preferred language
+ * New: read group identifier level 1 & 2
+ *
+ * *****************  Version 30  *****************
+ * User: Vo           Date: 30.08.99   Time: 14:23
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * bug fix
+ * new function
+ *
+ * *****************  Version 29  *****************
+ * User: Vo           Date: 9.08.99    Time: 13:11
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * PIN/PUK count
+ *
+ * *****************  Version 28  *****************
+ * User: Vo           Date: 26.07.99   Time: 14:34
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * Move include file mfw_cb.h
+ *
+ * *****************  Version 27  *****************
+ * User: Vo           Date: 21.07.99   Time: 14:41
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 26  *****************
+ * User: Vo           Date: 16.07.99   Time: 13:50
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 25  *****************
+ * User: Vo           Date: 9.07.99    Time: 14:34
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 24  *****************
+ * User: Vo           Date: 2.07.99    Time: 19:03
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 23  *****************
+ * User: Vo           Date: 28.05.99   Time: 9:52
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 22  *****************
+ * User: Vo           Date: 31.03.99   Time: 14:09
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 21  *****************
+ * User: Es           Date: 15.03.99   Time: 18:21
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * recode
+ *
+ * *****************  Version 20  *****************
+ * User: Vo           Date: 25.02.99   Time: 16:47
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 19  *****************
+ * User: Vo           Date: 17.02.99   Time: 19:03
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 18  *****************
+ * User: Vo           Date: 12.02.99   Time: 18:05
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 17  *****************
+ * User: Vo           Date: 12.02.99   Time: 17:46
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 16  *****************
+ * User: Vo           Date: 9.02.99    Time: 14:54
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 15  *****************
+ * User: Vo           Date: 12.01.99   Time: 14:27
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 14  *****************
+ * User: Es           Date: 23.12.98   Time: 15:47
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 12  *****************
+ * User: Es           Date: 18.12.98   Time: 13:05
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 11  *****************
+ * User: Vo           Date: 17.12.98   Time: 14:31
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 10  *****************
+ * User: Es           Date: 8.12.98    Time: 16:53
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ *
+ * *****************  Version 8  *****************
+ * User: Vo           Date: 24.11.98   Time: 21:40
+ * Updated in $/GSM/DEV/MS/SRC/MFW
+ * first successful compilation of MFW
+|
+| *****************  Version 6  *****************
+| User: Le           Date: 11.11.98   Time: 13:35
+| Updated in $/GSM/DEV/MS/SRC/MFW
+|
+| *****************  Version 5  *****************
+| User: Le           Date: 10.11.98   Time: 16:07
+| Updated in $/GSM/DEV/MS/SRC/MFW
+|
+| *****************  Version 4  *****************
+| User: Le           Date: 10.11.98   Time: 11:08
+| Updated in $/GSM/DEV/MS/SRC/MFW
+|
+| *****************  Version 3  *****************
+| User: Le           Date: 27.10.98   Time: 15:59
+| Updated in $/GSM/DEV/MS/SRC/MFW
+|
+| *****************  Version 2  *****************
+| User: Le           Date: 21.10.98   Time: 16:20
+| Updated in $/GSM/DEV/MS/SRC/MFW
+*/
+
+#define ENTITY_MFW
+
+#include <string.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+#if defined (NEW_FRAME)
+
+#include "typedefs.h"
+#include "vsi.h"
+#include "pei.h"
+#include "custom.h"
+#include "gsm.h"
+
+#else
+
+#include "stddefs.h"
+#include "custom.h"
+#include "gsm.h"
+#include "vsi.h"
+
+#endif
+
+#include "p_sim.h"
+#include "aci_cmh.h"
+#include "psa.h"
+#include "psa_sim.h"
+#include "pcm.h"
+#include "mfw_mfw.h"
+#include "mfw_nm.h"
+#include "mfw_sim.h"
+#include "mfw_sima.h"
+#include "mfw_simi.h"
+#include "mfw_nmi.h"
+#include "mfw_nma.h"
+#include "mfw_phb.h"
+#include "mfw_cm.h"
+#include "mfw_cmi.h"
+#include "mfw_acie.h"
+#include "mfw_sms.h"
+#include "mfw_smsi.h"
+#include "mfw_win.h"
+
+
+#include "ksd.h"
+#include "psa.h"
+
+#if defined (FAX_AND_DATA)
+#include "aci_fd.h"
+#endif
+
+#include "cmh.h"
+#include "phb.h"
+#include "cmh_phb.h"
+
+#include "mfw_ss.h"
+#include "mfw_ssi.h"
+
+#ifdef SIM_TOOLKIT
+#include "mfw_sat.h"
+#endif
+
+extern BOOL sima_response_cb (USHORT opc, void * data);
+extern void  simDecodeIMSI (UBYTE *ci, UBYTE li, UBYTE *di);
+extern UBYTE mfw_IMSI [];                  /* expanded IMSI (ASCIIZ)   */
+static T_MFW_SIM_STATUS sim_status;
+static T_MFW_SIM_CONFIG sim_config;
+static int pin_flag;
+static UBYTE pin_ident;
+
+UBYTE sim_nlock;                          /* Network lock             */
+UBYTE sim_splock;                         /* Service provider lock    */
+UBYTE sim_plock;                          /* SIM lock                 */
+UBYTE sim_nslock;                         /* Network SUBSET lock      */
+UBYTE sim_clock;                          /* corporate lock           */
+UBYTE sim_blocked;         					  		/* blocked flag			        */
+
+static UBYTE sim_service_table [10];      /* SIM service table        */
+static UBYTE sim_stat = SIM_NOT_ACTIVE;
+
+static int simCommand (ULONG cmd, void *h); /* handle win commands      */
+
+UBYTE pin1_set = MFW_SIM_UNKNOWN;
+UBYTE pin2_set = MFW_SIM_ENABLE;
+
+static BOOL sat_update = FALSE;
+
+static int pSlot;                       /* primitive handler slot   */
+
+EXTERN MfwHdr * current_mfw_elem;
+#if defined (WIN32)
+/*
+ * Only for windows to check several SIM lock combinations
+ */
+UBYTE sim_lock_mode = 0;     
+#endif
+UBYTE sim_lock_field = NOT_PRESENT_8BIT;  /* type of sim lock field   */
+
+static UBYTE sim_get_sim_lock      (EF_SIMLCKEXT * simlck);
+static void  sim_set_sim_lock      (EF_SIMLCKEXT * simlck);
+static void  sim_fill_sim_lock     (EF_SIMLCKEXT * simlck);
+static void  sim_check_unblock_sim (EF_SIMLCKEXT * simlck);
+
+#define SIMLOCK_DISABLED 0
+#define SIMLOCK_ENABLED  1
+#define SIMLOCK_LOCKED   2
+#define SIMLOCK_BLOCKED  3
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_init           |
++--------------------------------------------------------------------+
+
+  PURPOSE : initialize SIM manager
+
+*/
+
+int sim_init (void)
+{
+    EF_SIMLCKEXT simlck;
+
+    TRACE_FUNCTION("sim_init()");
+
+    /* 
+     * initialise SIM lock flags        
+     */
+    sim_nslock  = sim_plock = sim_nlock = sim_clock = sim_splock = 0; 
+    sim_blocked = FALSE;
+
+    /*
+     * Read SIM Lock Flags
+     */
+    if (sim_get_sim_lock (&simlck) EQ PCM_OK)
+    {
+      sim_plock  = (UBYTE) FldGet(simlck.locks1,plock);    
+      sim_nlock  = (UBYTE) FldGet(simlck.locks1,nlock);                                                        
+      sim_nslock = (UBYTE) FldGet(simlck.locks1,nslock); 
+      sim_splock = (UBYTE) FldGet(simlck.locks1,splock);   
+      sim_clock  = (UBYTE) FldGet(simlck.locks2,clock);   
+
+		  if (simlck.cnt >= simlck.maxcnt)
+			  sim_blocked = TRUE;
+		  else
+			  sim_blocked = FALSE;
+    }
+
+    pin_flag  = -1;
+	  pin_ident = MFW_SIM_UNKNOWN;
+
+    /* 
+     * install prim handler     
+     */
+    pSlot = aci_create(sima_response_cb,NULL);
+    mfwCommand[MfwTypSim] = (MfwCb) simCommand;
+
+    return TRUE;
+}
+
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM             |
+| STATE   : code                        ROUTINE : sim_init_sim_insert |
++---------------------------------------------------------------------+
+
+  PURPOSE : initialize SIM manager
+
+*/
+
+void sim_init_sim_insert()
+{
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_exit           |
++--------------------------------------------------------------------+
+
+  PURPOSE : finalize SIM manager
+
+*/
+
+void sim_exit (void)
+{
+    TRACE_FUNCTION("sim_exit()");
+
+    /* 
+     * remove prim handler      
+     */
+    aci_delete(pSlot);
+    sim_stat = SIM_NOT_ACTIVE;
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_create         |
++--------------------------------------------------------------------+
+
+  PURPOSE : create SIM event handler
+
+*/
+
+T_MFW_HND sim_create (MfwHnd hWin, MfwEvt event, MfwCb cbfunc)
+{
+    MfwHdr *hdr;
+    T_MFW_SIM *sim_para;
+
+    TRACE_FUNCTION("sim_create()");
+
+    hdr = (MfwHdr *) mfwAlloc(sizeof(MfwHdr));
+    sim_para = (T_MFW_SIM *) mfwAlloc(sizeof(T_MFW_SIM));
+
+    if (!hdr || !sim_para)
+        return 0;
+
+    sim_para->emask = event;
+    sim_para->handler = cbfunc;
+
+    hdr->data = sim_para;
+    hdr->type = MfwTypSim;
+
+    return mfwInsert((MfwHdr *) hWin,hdr);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_delete         |
++--------------------------------------------------------------------+
+
+  PURPOSE : delete SIM event handler
+
+*/
+
+MfwRes sim_delete (MfwHnd h)
+{
+    TRACE_FUNCTION("sim_delete()");
+
+    if (!h || !((MfwHdr *) h)->data)
+        return MfwResIllHnd;
+
+    if (!mfwRemove((MfwHdr *) h))
+        return MfwResIllHnd;
+
+    mfwFree((U8 *) ((MfwHdr *) h)->data,sizeof(T_MFW_SIM));
+    mfwFree((U8 *) h,sizeof(MfwHdr));
+
+    return MfwResOk;
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_signal         |
++--------------------------------------------------------------------+
+
+  PURPOSE : Send a signal
+
+*/
+
+void sim_signal (MfwEvt event, void *para)
+{
+    TRACE_FUNCTION ("sim_signal()");
+
+  if (mfwSignallingMethod EQ 0)
+  {
+    if (mfwFocus)
+        if (sim_sign_exec(mfwFocus,event,para))
+            return;
+    if (mfwRoot)
+        sim_sign_exec(mfwRoot,event,para);
+  }
+  else
+    {
+      MfwHdr * h = 0;
+
+      /*
+       * Focus set, then start here
+       */
+      if (mfwFocus)
+        h = mfwFocus;
+      /*
+       * Focus not set, then start root
+       */
+      if (!h)
+        h = mfwRoot;
+
+      /*
+       * No elements available, return
+       */
+
+      while (h)
+
+
+      {
+        /*
+         * Signal consumed, then return
+         */
+        if (sim_sign_exec (h, event, para))
+          return;
+
+        /*
+         * All windows tried inclusive root
+         */
+        if (h == mfwRoot)
+          return;
+
+        /*
+         * get parent window
+         */
+        h = mfwParent(mfwParent(h));
+		if(h)
+			h = ((MfwWin * )(h->data))->elems;
+      }
+      sim_sign_exec (mfwRoot, event, para);
+    }      
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_sign_exec      |
++--------------------------------------------------------------------+
+
+  PURPOSE : Send a signal if SIM management handler
+
+*/
+
+int sim_sign_exec (MfwHdr *cur_elem, MfwEvt event, T_MFW_SIM_PARA *para)
+{
+
+    TRACE_FUNCTION("sim_sign_exec()");
+
+    while (cur_elem)
+    {
+        if (cur_elem->type == MfwTypSim)
+        {
+            T_MFW_SIM *sim_data;
+            sim_data = (T_MFW_SIM *) cur_elem->data;
+            if (sim_data->emask & event)
+            {
+                sim_data->event = event;
+                switch (event)
+                {
+                    case E_SIM_STATUS:
+                        memcpy(&sim_data->para.status,
+                                para,sizeof(T_MFW_SIM_STATUS));
+                        break;
+                }
+                if (sim_data->handler)
+                {
+                  // PATCH LE 06.06.00
+                  // store current mfw elem
+                  current_mfw_elem = cur_elem;
+                  // END PATCH LE 06.06.00
+                  if ((*(sim_data->handler))(sim_data->event,
+                                             (void *) &sim_data->para))
+                    return TRUE;
+                }
+            }
+        }
+        cur_elem = cur_elem->next;
+    }
+
+    return FALSE;
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_activate       |
++--------------------------------------------------------------------+
+
+  PURPOSE : Start SIM card activation
+
+*/
+
+void sim_activate (void)
+{
+    TRACE_FUNCTION("sim_activate()");
+
+    /* 
+     * Full functionality is used donīt reset the ME 
+     */
+    if (sAT_PlusCFUN(CMD_SRC_LCL,CFUN_FUN_Full,CFUN_RST_NotPresent)
+        NEQ AT_EXCT)
+    {
+        TRACE_ERROR("sAT_PlusCFUN error");
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_spn_req        |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request service provider name
+
+*/
+
+void sim_spn_req (void)
+{
+    T_EF_SPN spn;
+
+    TRACE_FUNCTION("sim_spn_req()");
+
+    memset(&spn,0,sizeof(T_EF_SPN));
+
+    if (sim_check_service(17,sim_service_table)
+        EQ ALLOCATED_AND_ACTIVATED)
+        sim_read_sim(SIM_SPN,17,17);
+    else
+        nm_spn_cnf(&spn);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_ok_cfun        |
++--------------------------------------------------------------------+
+
+  PURPOSE : Notify successful end of SIM card activation
+
+*/
+
+void sim_ok_cfun (void)
+{
+    T_ACI_CFUN_FUN fun;
+
+    TRACE_FUNCTION ("sim_ok_cfun()");
+
+    qAT_PlusCFUN( CMD_SRC_LCL, &fun );
+
+    if( fun EQ CFUN_FUN_Full )
+    {
+      sim_stat = SIM_ACTIVE;
+      sim_status.sim_status = MFW_SIM_NO_PIN;
+      sim_status.sim_operation_mode = sim_config.oper_mode;
+      sim_status.sim_pin_retries = 0;
+      sim_status.sim_procedure = MFW_SIM_ACTIVATION;
+      sim_status.sim_status_type = pin_ident;
+
+      pin_ident = MFW_SIM_UNKNOWN;
+      sim_signal(E_SIM_STATUS,&sim_status);
+      nm_activate(MFW_SIM_NO_PIN);
+
+      pin1_set = MFW_SIM_DISABLE;
+    }
+    else if( fun EQ CFUN_FUN_Minimum )
+    {
+	    nm_ok_deregistration();
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_error_cfun     |
++--------------------------------------------------------------------+
+
+  PURPOSE : Notify error status of SIM card
+
+*/
+
+void sim_error_cfun (U8 result)
+{
+    TRACE_FUNCTION("sim_error_cfun()");
+
+    sim_status.sim_procedure = MFW_SIM_ACTIVATION;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+
+    switch (result)
+    {
+        case CME_ERR_SimPinReq:         /* PIN 1 must be entered    */
+            sim_status.sim_status = MFW_SIM_PIN_REQ;
+            sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN1);
+            sim_status.sim_status_type = MFW_SIM_PIN1;
+            sim_stat = SIM_ACTIVE;
+            break;
+        case CME_ERR_SimPin2Req:        /* PIN 2 must be entered    */
+            sim_status.sim_status = MFW_SIM_PIN2_REQ;
+            sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN2);
+            sim_status.sim_status_type = MFW_SIM_PIN2;
+            sim_stat = SIM_ACTIVE;
+            break;
+        case CME_ERR_SimPukReq:         /* PUK 1 must be entered    */
+            sim_status.sim_status = MFW_SIM_PUK_REQ;
+            sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PUK1);
+            sim_status.sim_status_type = MFW_SIM_PUK1;
+            sim_stat = SIM_ACTIVE;
+            break;
+        case CME_ERR_SimPuk2Req:        /* PUK 2 must be entered    */
+            sim_status.sim_status = MFW_SIM_PUK2_REQ;
+            sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PUK2);
+            sim_status.sim_status_type = MFW_SIM_PUK2;
+            sim_stat = SIM_ACTIVE;
+            break;
+        case CME_ERR_SimFail:           /* SIM card is invalid      */
+        case CME_ERR_SimWrong:
+            sim_status.sim_status = MFW_SIM_INVALID_CARD;
+            sim_status.sim_pin_retries = 0;
+            sim_status.sim_status_type = MFW_SIM_UNKNOWN;
+            sim_stat = SIM_NOT_ACTIVE;
+            break;
+        case CME_ERR_SimNotIns:         /* no SIM card inserted     */
+            sim_status.sim_status = MFW_SIM_NO_SIM_CARD;
+            sim_status.sim_pin_retries = 0;
+            sim_status.sim_status_type = MFW_SIM_UNKNOWN;
+            sim_stat = SIM_NOT_ACTIVE;
+            break;
+        default:
+            TRACE_ERROR("sim_error_cfun(): result");
+            return;
+    }
+
+    sim_signal(E_SIM_STATUS,&sim_status);
+
+    if ((result == CME_ERR_SimPinReq)
+        OR (result == CME_ERR_SimPukReq))
+        pin1_set = MFW_SIM_ENABLE;
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_error_cpin     |
++--------------------------------------------------------------------+
+
+  PURPOSE : Inform about error of PIN entering or PUK entering
+
+*/
+
+void sim_error_cpin (T_ACI_CME_ERR reason)
+{
+    T_ACI_CPIN_RSLT code;
+
+    TRACE_FUNCTION("sim_error_cpin()");
+
+    sim_status.sim_procedure = pin_flag;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+    sim_status.sim_status = MFW_SIM_FAILURE;
+    sim_status.sim_status_type = pin_ident;
+
+	  pin_flag = -1;
+	  pin_ident = MFW_SIM_UNKNOWN;
+
+    switch (reason)
+    {
+        case CME_ERR_WrongPasswd:
+            if (qAT_PlusCPIN(CMD_SRC_LCL,&code) != AT_CMPL)
+            {
+                TRACE_ERROR("sim_error_cpin():CPIN? failed");
+                sim_signal(E_SIM_STATUS,&sim_status);
+                return;
+            }
+            break;
+        case CME_ERR_SimWrong:
+			sim_status.sim_status = MFW_SIM_INVALID_CARD;
+            sim_signal(E_SIM_STATUS,&sim_status);
+            return;
+        default:
+            TRACE_ERROR("sim_error_cpin():Ill reason");
+            sim_signal(E_SIM_STATUS,&sim_status);
+            return;
+    }
+
+    switch (code)
+    {
+        case CPIN_RSLT_SimPinReq:
+            sim_status.sim_status = MFW_SIM_PIN_REQ;
+            sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN1);
+            break;
+        case CPIN_RSLT_SimPukReq:
+            sim_status.sim_status = MFW_SIM_PUK_REQ;
+            sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PUK1);
+            break;
+        case CPIN_RSLT_SimPin2Req:
+            sim_status.sim_status = MFW_SIM_PIN2_REQ;
+            sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN2);
+            break;
+        case CPIN_RSLT_SimPuk2Req:
+            sim_status.sim_status = MFW_SIM_PUK2_REQ;
+            sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PUK2);
+            break;
+        case CPIN_RSLT_NotPresent:
+        case CPIN_RSLT_SimReady:
+        default:
+            TRACE_ERROR("sim_error_cpin():Ill code");
+            break;
+    }
+
+    sim_signal(E_SIM_STATUS,&sim_status);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_ok_cpin        |
++--------------------------------------------------------------------+
+
+  PURPOSE : Successful end of PIN entering or PUK entering
+
+*/
+
+void sim_ok_cpin (void)
+{
+    TRACE_FUNCTION("sim_ok_cpin()");
+
+    switch (pin_flag)
+    {
+        case MFW_SIM_VERIFY:
+            sim_status.sim_procedure = MFW_SIM_VERIFY;
+            sim_status.sim_status = MFW_SIM_NO_PIN;
+            sim_status.sim_status_type = pin_ident;
+            break;
+        case MFW_SIM_UNBLOCK:
+            sim_status.sim_procedure = MFW_SIM_UNBLOCK;
+            sim_status.sim_status = MFW_SIM_SUCCESS;
+            sim_status.sim_status_type = pin_ident;
+            break;
+        default:
+            break;
+    }
+
+    pin_flag = -1;
+	  pin_ident = MFW_SIM_UNKNOWN;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+    sim_status.sim_pin_retries = 0;
+
+    sim_signal (E_SIM_STATUS, &sim_status);
+    if (nm_reg_flag_req())
+      nm_activate(MFW_SIM_NO_PIN);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_ss_unblock     |
++--------------------------------------------------------------------+
+
+  PURPOSE : SIM unblock via SS string
+
+*/
+
+void sim_ss_unblock(UBYTE result, T_ACI_CME_ERR reason)
+{
+    TRACE_FUNCTION("sim_ss_unblock()");
+        
+    pin_flag = MFW_SIM_UNBLOCK;
+
+    if (result == SIM_UBLK_ERROR)
+        sim_error_cpin (reason);
+    if (result == SIM_UBLK_OK)
+        sim_ok_cpin ();
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_verify_pin     |
++--------------------------------------------------------------------+
+
+  PURPOSE : Verify PIN
+
+*/
+
+void sim_verify_pin (U8 pin_id, char *pin)
+{
+	TRACE_FUNCTION("sim_verify_pin()");
+
+    pin_flag = MFW_SIM_VERIFY;
+	  pin_ident = pin_id;
+    switch (pin_id)
+    {
+        case MFW_SIM_PIN1:
+            sAT_PercentPVRF(CMD_SRC_LCL, PVRF_TYPE_Pin1, pin, 0);
+            break;
+        case MFW_SIM_PIN2:
+            sAT_PercentPVRF(CMD_SRC_LCL, PVRF_TYPE_Pin2, pin, 0);
+            break;
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_unblock_pin    |
++--------------------------------------------------------------------+
+
+  PURPOSE : unblock SIM
+
+*/
+
+void sim_unblock_pin (U8 pin_id, char *puk, char *newpin)
+{
+    TRACE_FUNCTION("sim_unblock_pin()");
+
+    pin_flag = MFW_SIM_UNBLOCK;
+	  pin_ident = pin_id;
+    switch (pin_id)
+    {
+        case MFW_SIM_PUK1:
+            sAT_PercentPVRF(CMD_SRC_LCL, PVRF_TYPE_Puk1, puk, newpin);
+            break;
+        case MFW_SIM_PUK2:
+            sAT_PercentPVRF(CMD_SRC_LCL, PVRF_TYPE_Puk2, puk, newpin);
+            break;
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_change_pin     |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request of PIN change
+
+*/
+
+void sim_change_pin (U8 pin_id, U8 *old_pin, U8 *new_pin)
+{
+    TRACE_FUNCTION("sim_change_pin()");
+
+    pin_ident = pin_id;
+    switch (pin_id)
+    {
+        case MFW_SIM_PIN1:
+            sAT_PlusCPWD(CMD_SRC_LCL, CPWD_FAC_Sc,
+                         (char *)old_pin, (char *)new_pin);
+            break;
+        case MFW_SIM_PIN2:
+            sAT_PlusCPWD(CMD_SRC_LCL, CPWD_FAC_P2,
+                         (char *)old_pin, (char *)new_pin);
+            break;
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_ok_cpinc       |
++--------------------------------------------------------------------+
+
+  PURPOSE : Notify successful end of PIN change
+
+*/
+
+void sim_ok_cpinc (void)
+{
+    TRACE_FUNCTION("sim_ok_cpinc()");
+
+    sim_status.sim_procedure = MFW_SIM_CHANGE;
+    sim_status.sim_status = MFW_SIM_SUCCESS;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+    sim_status.sim_pin_retries = 0;
+    sim_status.sim_status_type = pin_ident;
+
+    pin_ident = MFW_SIM_UNKNOWN;
+    sim_signal(E_SIM_STATUS,&sim_status);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_error_cpinc    |
++--------------------------------------------------------------------+
+
+  PURPOSE : Notify failed PIN change
+
+*/
+
+void sim_error_cpinc (void)
+{
+    TRACE_FUNCTION("sim_error_cpinc()");
+
+    sim_status.sim_procedure = MFW_SIM_CHANGE;
+    sim_status.sim_status = MFW_SIM_FAILURE;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+    if (pin_ident EQ MFW_SIM_PIN1)
+      sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN1);
+    else if (pin_ident EQ MFW_SIM_PIN2)
+      sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN2);
+    else
+      sim_status.sim_pin_retries = 0;
+    sim_status.sim_status_type = pin_ident;
+
+    pin_ident = MFW_SIM_UNKNOWN;
+    sim_signal(E_SIM_STATUS,&sim_status);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_disable_pin    |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request PIN disability
+
+*/
+
+void sim_disable_pin (U8 *pin)
+{
+    TRACE_FUNCTION("sim_disable_pin()");
+
+    ss_set_clck(CLCK_FAC_Sc, CLCK_MOD_Unlock,
+               (char *)pin, -1, MFW_SIM_CPIND);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_ok_cpind       |
++--------------------------------------------------------------------+
+
+  PURPOSE : Successful end of PIN disability
+
+*/
+
+void sim_ok_cpind (void)
+{
+    TRACE_FUNCTION("sim_ok_cpind()");
+
+    sim_status.sim_procedure = MFW_SIM_DISABLE;
+    sim_status.sim_status = MFW_SIM_SUCCESS;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+    sim_status.sim_pin_retries = 0;
+    sim_status.sim_status_type = MFW_SIM_UNKNOWN; // no indication
+
+    pin1_set = MFW_SIM_DISABLE;
+    sim_signal(E_SIM_STATUS,&sim_status);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_error_cpind    |
++--------------------------------------------------------------------+
+
+  PURPOSE : Failed PIN disability
+
+*/
+
+void sim_error_cpind (void)
+{
+    TRACE_FUNCTION("sim_error_cpind()");
+
+    sim_status.sim_procedure = MFW_SIM_DISABLE;
+    sim_status.sim_status = MFW_SIM_FAILURE;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+    sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN1);
+    sim_status.sim_status_type = MFW_SIM_UNKNOWN; // no indication
+
+    sim_signal(E_SIM_STATUS,&sim_status);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_enable_pin     |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request PIN enability
+
+*/
+
+void sim_enable_pin (U8 *pin)
+{
+    TRACE_FUNCTION("sim_enable_pin()");
+
+    ss_set_clck(CLCK_FAC_Sc, CLCK_MOD_Lock,
+               (char *)pin, -1, MFW_SIM_CPINE);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_ok_cpine       |
++--------------------------------------------------------------------+
+
+  PURPOSE : Successful end of PIN enability
+
+*/
+
+void sim_ok_cpine()
+{
+    TRACE_FUNCTION("sim_ok_cpine()");
+
+    sim_status.sim_procedure = MFW_SIM_ENABLE;
+    sim_status.sim_status = MFW_SIM_SUCCESS;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+    sim_status.sim_pin_retries = 0;
+    sim_status.sim_status_type = MFW_SIM_UNKNOWN; // no indication
+
+    pin1_set = MFW_SIM_ENABLE;
+    sim_signal(E_SIM_STATUS,&sim_status);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_error_cpine    |
++--------------------------------------------------------------------+
+
+  PURPOSE : Failed PIN enability
+
+*/
+
+void sim_error_cpine (void)
+{
+    TRACE_FUNCTION("sim_error_cpine()");
+
+    sim_status.sim_procedure = MFW_SIM_ENABLE;
+    sim_status.sim_status = MFW_SIM_FAILURE;
+    sim_status.sim_operation_mode = sim_config.oper_mode;
+    sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN1);
+    sim_status.sim_status_type = MFW_SIM_UNKNOWN; // no indication
+
+    sim_signal(E_SIM_STATUS,&sim_status);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)         MODULE  : MFW_SIM           |
+| STATE   : code                         ROUTINE : sim_check_service |
++--------------------------------------------------------------------+
+
+  PURPOSE : Checks a service status
+
+*/
+
+U8 sim_check_service (U8 nr, U8 *serv_table)
+{
+    U8 value;
+
+    TRACE_FUNCTION("sim_check_service()");
+
+    value = *(serv_table + (nr - 1) / 4);
+    value >>=  ((nr - 1) & 3) * 2;
+
+    return (value & 3);
+}
+
+
+/*
++-----------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)         MODULE  : MFW_SIM              |
+| STATE   : code                         ROUTINE : sim_serv_table_check |
++-----------------------------------------------------------------------+
+
+  PURPOSE : Checks a service status in SIM service table
+
+*/
+
+T_MFW sim_serv_table_check(UBYTE serv_num)
+{
+  TRACE_FUNCTION("sim_serv_table_check()");
+  return sim_check_service(serv_num, sim_service_table);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)         MODULE  : MFW_SIM           |
+| STATE   : code                         ROUTINE : rAT_PlusCFUNP     |
++--------------------------------------------------------------------+
+
+  PURPOSE : MMI relevant parameters from the SIM card
+
+*/
+
+void rAT_PlusCFUNP (T_SIM_MMI_INSERT_IND *mmi_insert_ind)
+{
+    TRACE_FUNCTION("rAT_PlusCFUNP()");
+
+    sim_stat = SIM_ACTIVE;
+
+    sim_config.oper_mode = mmi_insert_ind->func;
+    //  sms_mmi_parameter(mmi_insert_ind->cbmid);
+    nm_mmi_parameters(&mmi_insert_ind->imsi_field,
+                        &mmi_insert_ind->pref_plmn);
+    memcpy(sim_service_table,mmi_insert_ind->sim_serv,
+                                sizeof(sim_service_table));
+    //memcpy(sim_config.deper_key,mmi_insert_ind->deper_key,
+    //                            sizeof(sim_config.deper_key));
+    sim_config.phase = mmi_insert_ind->phase;
+    sim_config.access_acm = mmi_insert_ind->access_acm;
+    sim_config.access_acmmax = mmi_insert_ind->access_acmmax;
+    sim_config.access_puct = mmi_insert_ind->access_puct;
+
+//    sim_init_sim_insert();
+
+    if (sim_check_service(15,sim_service_table)
+        == ALLOCATED_AND_ACTIVATED)
+        sim_read_sim(SIM_GID1, NOT_PRESENT_8BIT, 5);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)         MODULE  : MFW_SIM           |
+| STATE   : code                         ROUTINE : sim_mmi_parameter |
++--------------------------------------------------------------------+
+
+  PURPOSE : MMI relevant parameters from the SIM card
+
+*/
+
+void sim_mmi_parameter(T_SIM_ACTIVATE_CNF *sim_act_cnf)
+{
+  TRACE_FUNCTION("sim_mmi_parameter()");
+
+  memcpy( sim_config.pref_lang, sim_act_cnf->pref_lang, 5);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)         MODULE  : MFW_SIM           |
+| STATE   : code                         ROUTINE : sim_gid1_cnf      |
++--------------------------------------------------------------------+
+
+  PURPOSE : read SIM group identifier 1 from SIM card
+
+*/
+
+void sim_gid1_cnf(SHORT error, UBYTE *data)
+{
+  TRACE_FUNCTION("sim_gid1_cnf()");
+
+  if (error EQ SIM_NO_ERROR)
+    memcpy(sim_config.sim_gidl1, data, 5);
+
+  if (!sat_update)
+  {
+    if (sim_check_service(16,sim_service_table)
+        == ALLOCATED_AND_ACTIVATED)
+        sim_read_sim(SIM_GID2, NOT_PRESENT_8BIT, 5);
+  }
+#ifdef SIM_TOOLKIT
+  else
+  {
+    sat_update = FALSE;
+    satUpdateFiles ( TRUE, SIM_GID1 );
+  }
+#endif
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)         MODULE  : MFW_SIM           |
+| STATE   : code                         ROUTINE : sim_gid2_cnf      |
++--------------------------------------------------------------------+
+
+  PURPOSE : read SIM group identifier 2 from SIM card
+
+*/
+
+void sim_gid2_cnf(SHORT error, UBYTE *data)
+{
+  TRACE_FUNCTION("sim_gid2_cnf()");
+  if (error EQ SIM_NO_ERROR)
+    memcpy(sim_config.sim_gidl2, data, 5);
+
+#ifdef SIM_TOOLKIT
+  if ( sat_update )
+  {
+    sat_update = FALSE;
+    satUpdateFiles ( TRUE, SIM_GID2 );
+  }
+#endif
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_save_pref_lang |
++--------------------------------------------------------------------+
+
+  PURPOSE : save preferred language
+
+*/
+
+void sim_save_pref_lang (UBYTE *lang, UBYTE len)
+{
+  UBYTE sim_data[7];
+  UBYTE i;
+
+  TRACE_FUNCTION("sim_save_pref_lang()");
+
+  //
+  // copy a maximum of 5 bytes for storing on the SIM card
+  //
+  for (i=0;i<len AND i<5;i++)
+    sim_data[i] = lang[i];
+
+  //
+  // if less than 5 bytes fill with dummy values
+  //
+  for (i=len; i<5;i++)
+    sim_data[i] = 0xFF;
+
+  //
+  // write to the SIM card
+  //
+  sim_write_sim(SIM_LP, sim_data, 5);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : rAT_PercentSIMREM  |
++--------------------------------------------------------------------+
+
+  PURPOSE : call back for SIM removed
+
+*/
+
+void rAT_PercentSIMREM( T_ACI_SIMREM_TYPE srType )
+{
+    TRACE_FUNCTION("rAT_PercentSIMREM()");
+
+    if ( srType EQ SIMREM_FAILURE )
+    {
+      sim_status.sim_procedure = MFW_SIM_REMOVED;
+      sim_status.sim_status = MFW_SIM_NO_SIM_CARD;
+      sim_status.sim_operation_mode = sim_config.oper_mode;
+      sim_status.sim_pin_retries = 0;
+      sim_status.sim_status_type = MFW_SIM_UNKNOWN;
+      sim_stat = SIM_NOT_ACTIVE;
+      sim_signal(E_SIM_STATUS,&sim_status);
+    }
+    else if ( srType EQ SIMREM_RESET )
+    {
+#ifdef SIM_TOOLKIT
+      sim_signal(E_SIM_RESET, 0); 
+#endif
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : rAT_percentSIMINS  |
++--------------------------------------------------------------------+
+
+  PURPOSE : call back for SIM inserted
+
+*/
+
+void rAT_PercentSIMINS( T_ACI_CME_ERR err )
+{
+    TRACE_FUNCTION("rAT_percentSIMINS()");
+
+    sim_signal(E_SIM_INSERTED, 0);
+
+    switch ( err )
+    {
+      case CME_ERR_SimPinReq:
+        sim_status.sim_status = MFW_SIM_PIN_REQ;
+        sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PIN1);
+        sim_status.sim_status_type = MFW_SIM_PIN1;
+        sim_stat = SIM_ACTIVE;
+        sim_signal(E_SIM_STATUS, &sim_status);
+        break;
+
+      case CME_ERR_SimPukReq:
+        sim_status.sim_status = MFW_SIM_PUK_REQ;
+        sim_status.sim_pin_retries = sim_pin_count(MFW_SIM_PUK1);
+        sim_status.sim_status_type = MFW_SIM_PUK1;
+        sim_stat = SIM_ACTIVE;
+        sim_signal(E_SIM_STATUS, &sim_status);
+        break;
+
+      default:
+        break;
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_configuration  |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request the configuration of SIM card
+
+*/
+
+UBYTE sim_cvt_access_status(UBYTE acs)
+{
+    TRACE_FUNCTION("sim_cvt_access_status()");
+    
+    switch(acs)
+    {
+        case ACCESS_ALWAYS: return MFW_SIM_NO_PIN;
+        case ACCESS_PIN_1:  return MFW_SIM_PIN1;
+        case ACCESS_PIN_2:  return MFW_SIM_PIN2;
+        default:            return MFW_SIM_UNKNOWN;
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_configuration  |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request the configuration of SIM card
+
+*/
+
+MfwRes sim_configuration (U8 *phase, U8 *serv, U8 *slen,
+                          U8 *lang, U8 *llen,
+                          T_MFW_AOC_ACCESS *access)
+{
+    U8 l;
+    TRACE_FUNCTION("sim_configuration()");
+
+		//PATCH2 TB 1310: Add test of NULL parameter to avoid to declare parameter of unwanted data
+    if (sim_stat != SIM_ACTIVE)
+        return MFW_SIM_FAILURE;
+
+		if (phase != NULL)
+			*phase = sim_config.phase;
+
+		if ((serv != NULL) && (slen != NULL))
+		{			
+			l = sizeof(sim_service_table);
+			if (l < *slen)
+					*slen = l;
+			memcpy(serv,sim_service_table,*slen);
+		}
+
+    //PATCH1 TB 1310: replace slen by llen
+		if ((lang != NULL) && (llen != NULL))
+		{
+			l = sizeof(sim_config.pref_lang);
+			if (l < *llen)
+					*llen = l;
+			memcpy(lang, sim_config.pref_lang, *llen);
+		}
+		//END PATCH1 TB
+
+		if (access != NULL)
+		{
+			access->access_acm    = sim_cvt_access_status(sim_config.access_acm);
+			access->access_acmmax = sim_cvt_access_status(sim_config.access_acmmax);
+			access->access_puct   = sim_cvt_access_status(sim_config.access_puct);
+		}
+		//END PATCH2 TB
+
+    return MFW_SIM_SUCCESS;
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_status_check   |
++--------------------------------------------------------------------+
+
+  PURPOSE : check activation of SIM card
+
+*/
+
+int sim_status_check (void)
+{
+    TRACE_FUNCTION("sim_status_check()");
+
+    return sim_stat;
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_pin_count      |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request PIN/PUK count
+
+*/
+
+int sim_pin_count(U8 pin_id)
+{
+    SHORT        pn1Cnt;
+    SHORT        pn2Cnt;
+    SHORT        pk1Cnt;
+    SHORT        pk2Cnt;
+    T_ACI_PVRF_STAT ps1;
+    T_ACI_PVRF_STAT ps2;
+        
+    TRACE_FUNCTION("sim_pin_count()");
+
+
+    if (qAT_PercentPVRF(CMD_SRC_LCL, &pn1Cnt,
+                        &pn2Cnt, &pk1Cnt, &pk2Cnt, &ps1, &ps2) != AT_CMPL)
+        return -1;
+
+    switch (pin_id)
+    {
+        case MFW_SIM_PIN1:  return pn1Cnt;
+        case MFW_SIM_PIN2:  return pn2Cnt;
+        case MFW_SIM_PUK1:  return pk1Cnt;
+        case MFW_SIM_PUK2:  return pk2Cnt;
+        default:            return -1;
+    }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : simDecodeB2A       |
++--------------------------------------------------------------------+
+
+  PURPOSE : convert bcd to ASCII
+
+*/
+
+void simDecodeB2A (U8 *ci, U8 li, U8 *di)
+{
+    int i;
+    
+    TRACE_FUNCTION("simDecodeB2A()");
+
+    for (i = 0; i < li * 2; i++)
+    {
+        di[i] = (i & 1) ? (ci[i/2] >> 4) + '0'
+                        : (ci[i/2] & 0x0f) + '0';
+        if (di[i] > '9')
+        {
+            di[i] = 0;
+            break;
+        }
+    }
+    di[i] = 0;
+}
+
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM             |
+| STATE   : code                        ROUTINE : sim_unlock_sim_lock |
++---------------------------------------------------------------------+
+
+  PURPOSE : de-personalisation for SIM lock.
+
+*/
+
+T_MFW sim_unlock_sim_lock(UBYTE type, UBYTE *passwd)
+{
+  UBYTE        eep_ckey [LONG_NAME];  // extracted version of PCM content          
+  EF_SIMLCKEXT simlck;
+
+  TRACE_FUNCTION("sim_unlock_sim_lock()");
+
+  /*
+   * Read SIM LOCK Record from PCM
+   */
+  if (sim_get_sim_lock (&simlck) NEQ PCM_OK)
+  {
+    TRACE_ERROR("No SIMLCK");
+    return MFW_SIM_UNLOCK_ERR;
+  }
+
+  /*
+   * check whether card is already blocked
+   */
+	if (simlck.cnt >= simlck.maxcnt)
+		return MFW_SIM_BLOCKED;
+
+  switch (type)
+  {
+    /*
+     * N-Lock
+     */
+    case MFW_SIM_NLOCK:
+      /*
+       * Extract Key from PCM record
+       */
+      simDecodeB2A (simlck.NKey, 8, eep_ckey);
+      if (!strcmp((char *)eep_ckey, (char *)passwd))
+			{
+        /*
+         * unblock password is okay
+         */
+				sim_nlock     = SIMLOCK_ENABLED;
+				simlck.locks1 = (UBYTE) FldSet(simlck.locks1,nlock,sim_nlock);
+				simlck.cnt    = 0;
+				sim_set_sim_lock (&simlck);
+
+				return MFW_SIM_NLOCK;
+			}
+			break;
+
+    /*
+     * SP-Lock
+     */
+    case MFW_SIM_SPLOCK:
+      /*
+       * Extract Key from PCM record
+       */
+      simDecodeB2A (simlck.SPKey, 8, eep_ckey);
+      if (!strcmp((char *)eep_ckey, (char *)passwd))
+      {
+        /*
+         * unblock password is okay
+         */
+				sim_splock    = SIMLOCK_ENABLED;
+				simlck.locks1 = (UBYTE) FldSet(simlck.locks1,splock,sim_splock);
+				simlck.cnt    = 0;
+				sim_set_sim_lock (&simlck);
+
+        return MFW_SIM_SPLOCK;
+			}
+			break;
+    
+    /*
+     * NS-Lock
+     */
+    case MFW_SIM_NSLOCK:
+      /*
+       * Extract Key from PCM record
+       */
+      simDecodeB2A (simlck.NSKey, 8, eep_ckey);
+      if (!strcmp((char *)eep_ckey, (char *)passwd))
+      {
+        /*
+         * unblock password is okay
+         */
+   			sim_nslock    = SIMLOCK_ENABLED;
+				simlck.locks1 = (UBYTE) FldSet(simlck.locks1,nslock,sim_nslock);
+				simlck.cnt    = 0;
+				sim_set_sim_lock (&simlck);
+
+				return MFW_SIM_NSLOCK;
+			}
+			break;
+
+    /*
+     * C-Lock
+     */
+    case MFW_SIM_CLOCK:
+      /*
+       * Extract Key from PCM record
+       */
+      simDecodeB2A (simlck.CKey, 8, eep_ckey);
+      if (!strcmp((char *)eep_ckey, (char *)passwd))
+      {
+        /*
+         * unblock password is okay
+         */
+				sim_clock     = SIMLOCK_ENABLED;
+				simlck.locks2 = (UBYTE) FldSet(simlck.locks2,clock,sim_clock);
+				simlck.cnt    = 0;
+				sim_set_sim_lock (&simlck);
+
+				return MFW_SIM_CLOCK;
+			}
+			break;
+
+    /*
+     * P-Lock
+     */
+    case MFW_SIM_PLOCK:
+      /*
+       * Extract Key from PCM record
+       */
+      simDecodeB2A (simlck.PKey, 8, eep_ckey);
+      if (!strcmp((char *)eep_ckey, (char *)passwd))
+      {
+        /*
+         * unblock password is correct
+         */
+				sim_plock     = SIMLOCK_ENABLED;
+				simlck.locks1 = (UBYTE) FldSet(simlck.locks1,plock,sim_plock);
+				simlck.cnt    = 0;
+				sim_set_sim_lock (&simlck);
+
+				return MFW_SIM_PLOCK;
+			}
+			break;
+
+    default:
+      return MFW_SIM_UNLOCK_ERR;
+  }
+
+  /*
+   * another failed attempt
+   * increment counter, store in PCM and may change the status
+   */
+	simlck.cnt++;
+	sim_set_sim_lock (&simlck);
+
+	if (simlck.cnt >= simlck.maxcnt)
+	{
+		sim_blocked = TRUE;    
+		return MFW_SIM_BLOCKED;
+	}
+	else
+		return MFW_SIM_UNLOCK_ERR;
+}
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM             |
+| STATE   : code                        ROUTINE : sim_check_sim_Plock |
++---------------------------------------------------------------------+
+
+  PURPOSE : check SIM lock
+
+*/
+
+int sim_check_sim_Plock (void)
+{
+  EF_SIMLCKEXT simlck;
+  UBYTE        i;
+
+  TRACE_FUNCTION ("sim_check_sim_Plock()");
+
+
+	if (sim_blocked EQ TRUE OR 
+      sim_plock   EQ SIMLOCK_BLOCKED)
+  {
+    /*
+     * Try to reset unlock attempt counter
+     */
+    sim_check_unblock_sim (&simlck);
+		return MFW_SIM_BLOCKED;
+  }
+
+  /* 
+   * lock check disabled      
+   */
+  if (sim_plock EQ SIMLOCK_DISABLED) 
+    return MFW_SIM_DISABLE;
+
+  /* 
+   * lock check blocked      
+   */
+  if (sim_plock EQ SIMLOCK_LOCKED)              
+    return MFW_SIM_LOCKED;
+
+  /*
+   * lock check enabled       
+   */
+  if (sim_plock EQ SIMLOCK_ENABLED)              
+  {
+    if (sim_get_sim_lock (&simlck) NEQ PCM_OK)
+    {
+      TRACE_ERROR("No SIMLCK");
+      return MFW_SIM_FAILURE;     
+    }
+
+    /*
+     * Check all digits
+     */
+		for (i=0; i<simlck.len_p_imsi; i++)
+		{
+			if (sim_check_imsi_digit(simlck.p_imsi[i], mfw_IMSI[i]) EQ FALSE)
+				break;
+		}
+    
+    /*
+     * all digits okay
+     */
+		if (i EQ simlck.len_p_imsi)
+			return MFW_SIM_ENABLE;
+
+    /*
+     * P-LOCK check failed
+     */
+
+    sim_plock     = SIMLOCK_LOCKED;
+		simlck.locks1 = (UBYTE) FldSet(simlck.locks1,plock,sim_plock);
+		sim_set_sim_lock (&simlck);
+    return MFW_SIM_LOCKED;
+  }
+
+  /*
+   * shall not happen
+   */
+  return MFW_SIM_FAILURE;
+}
+
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM             |
+| STATE   : code                        ROUTINE : sim_check_sim_Nlock |
++---------------------------------------------------------------------+
+
+  PURPOSE : Check network lock
+
+*/
+
+int sim_check_sim_Nlock (void)
+{
+  EF_SIMLCKEXT simlck;
+	UBYTE        i;
+
+  TRACE_FUNCTION ("sim_check_sim_Nlock()");
+
+	if (sim_blocked EQ TRUE OR 
+      sim_nlock   EQ SIMLOCK_BLOCKED)
+  {
+    /*
+     * Try to reset unlock attempt counter
+     */
+    sim_check_unblock_sim (&simlck);
+		return MFW_SIM_BLOCKED;
+  }
+
+  /*
+   * lock check disabled
+   */
+  if (sim_nlock EQ SIMLOCK_DISABLED)             
+    return MFW_SIM_DISABLE;
+
+  /*
+   * lock check blocked
+   */
+  if (sim_nlock EQ SIMLOCK_LOCKED)            
+        return MFW_SIM_LOCKED;
+
+  /*
+   * lock check enabled
+   */
+  if (sim_nlock EQ SIMLOCK_ENABLED)
+  {
+    if (sim_get_sim_lock (&simlck) NEQ PCM_OK)
+    {
+      TRACE_ERROR("No SIMLCK");
+      return MFW_SIM_FAILURE;     
+    }
+
+    /*
+     * check all digits
+     */
+		for (i=0; i<simlck.len_n_imsi; i++)	
+    {
+      if (sim_check_imsi_digit(simlck.n_imsi[i], mfw_IMSI[i]) EQ FALSE)
+				break;
+		}
+
+    /*
+     * all digits okay
+     */
+		if (i EQ simlck.len_n_imsi)
+			return MFW_SIM_ENABLE;
+
+    /*
+     * N-LOCK check failed
+     */
+    sim_nlock     = SIMLOCK_LOCKED;
+		simlck.locks1 = (U8) FldSet(simlck.locks1,nlock,sim_nlock);
+		sim_set_sim_lock (&simlck);
+    return MFW_SIM_LOCKED;
+  }
+  /*
+   * shall not happen
+   */
+  return MFW_SIM_FAILURE;
+}
+
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM             |
+| STATE   : code                        ROUTINE : sim_check_sim_SPlock|
++---------------------------------------------------------------------+
+
+  PURPOSE : Check SIM service provider lock. It only works with SIMs
+            which support GID1 file.
+
+*/
+
+int sim_check_sim_SPlock (void)
+{
+  EF_SIMLCKEXT simlck;
+	UBYTE        i;
+
+  TRACE_FUNCTION ("sim_check_sim_SPlock()");
+
+  /*
+   * Only if Service 15 is activated and allocated
+   */
+  if (sim_check_service(15,sim_service_table) NEQ ALLOCATED_AND_ACTIVATED)
+    return MFW_SIM_FAILURE;
+
+	if (sim_blocked EQ TRUE OR 
+      sim_splock  EQ SIMLOCK_BLOCKED)
+  {
+    /*
+     * Try to reset unlock attempt counter
+     */
+    sim_check_unblock_sim (&simlck);
+		return MFW_SIM_BLOCKED;
+  }
+
+  /*
+   * lock check disabled
+   */
+  if (sim_splock EQ SIMLOCK_DISABLED)
+    return MFW_SIM_DISABLE;
+
+  /*
+   * lock check blocked
+   */
+  if (sim_splock EQ SIMLOCK_LOCKED)
+    return MFW_SIM_LOCKED;
+
+  /*
+   * lock check enabled
+   */
+  if (sim_splock EQ SIMLOCK_ENABLED)             
+  {
+    if (sim_get_sim_lock (&simlck) NEQ PCM_OK)
+    {
+      TRACE_ERROR("No SIMLCK");
+      return MFW_SIM_FAILURE;     
+    }
+
+    /* 
+     * check SP group identifier 
+     */
+    if (memcmp(&simlck.gidl1, sim_config.sim_gidl1, 1))
+    {
+      sim_splock    = SIMLOCK_LOCKED;
+			simlck.locks1 = (UBYTE) FldSet(simlck.locks1,splock,sim_splock);
+			sim_set_sim_lock (&simlck);
+      
+      return MFW_SIM_LOCKED;
+    }
+
+    /* 
+     * check all digits
+     */
+		for (i=0; i<simlck.len_sp_imsi; i++)
+		{
+			if (sim_check_imsi_digit(simlck.sp_imsi[i], mfw_IMSI[i]) EQ FALSE)
+				break;
+		}
+
+    /*
+     * all digits okay
+     */
+		if (i EQ simlck.len_sp_imsi)
+			return MFW_SIM_ENABLE;
+
+    /*
+     * failed SP-Lock
+     */
+    sim_splock    = SIMLOCK_LOCKED;
+		simlck.locks1 = (UBYTE) FldSet(simlck.locks1,splock,sim_splock);
+		sim_set_sim_lock (&simlck);
+
+    return MFW_SIM_LOCKED;
+  }
+  /*
+   * shall not happen
+   */
+  return MFW_SIM_FAILURE;
+}
+
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM             |
+| STATE   : code                        ROUTINE : sim_check_sim_NSlock|
++---------------------------------------------------------------------+
+
+  PURPOSE : Check network subset lock
+
+*/
+
+int sim_check_sim_NSlock (void)
+{
+  EF_SIMLCKEXT simlck;
+	UBYTE        i;
+
+  TRACE_FUNCTION ("sim_check_sim_NSlock()");
+
+	if (sim_blocked EQ TRUE OR 
+      sim_nslock  EQ SIMLOCK_BLOCKED)
+  {
+    /*
+     * Try to reset unlock attempt counter
+     */
+    sim_check_unblock_sim (&simlck);
+		return MFW_SIM_BLOCKED;
+  }
+
+  /* 
+   * lock check disabled
+   */
+  if (sim_nslock EQ SIMLOCK_DISABLED)
+    return MFW_SIM_DISABLE;
+
+  /*
+   * lock check blocked
+   */
+  if (sim_nslock EQ SIMLOCK_LOCKED)
+    return MFW_SIM_LOCKED;
+
+  /*
+   * lock check enabled
+   */
+  if (sim_nslock EQ SIMLOCK_ENABLED)
+  {
+    if (sim_get_sim_lock (&simlck) NEQ PCM_OK)
+    {
+      TRACE_ERROR("No SIMLCK");
+      return MFW_SIM_FAILURE;     
+    }
+
+    /*
+     * check all digits
+     */
+    for (i=0; i<simlck.len_ns_imsi; i++)
+		{
+			if (sim_check_imsi_digit(simlck.ns_imsi[i], mfw_IMSI[i]) EQ FALSE)
+				break;
+		}
+
+    /*
+     * all digits okay
+     */
+		if (i EQ simlck.len_ns_imsi)
+			return MFW_SIM_ENABLE;
+
+    /*
+     * Lock has failed
+     */
+    sim_nslock    = SIMLOCK_LOCKED;
+		simlck.locks1 = (UBYTE) FldSet(simlck.locks1,nslock,sim_nslock);
+		sim_set_sim_lock (&simlck);
+
+    return MFW_SIM_LOCKED;
+  }
+
+  /*
+   * shall not happen
+   */
+  return MFW_SIM_FAILURE;
+}
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM             |
+| STATE   : code                        ROUTINE : sim_check_sim_Clock |
++---------------------------------------------------------------------+
+
+  PURPOSE : Check corporate lock. It only works with SIMs
+            which support GID1 and GID2 files.
+
+*/
+
+int sim_check_sim_Clock (void)
+{
+  EF_SIMLCKEXT simlck;
+  UBYTE        i;
+
+  TRACE_FUNCTION ("sim_check_sim_Clock()");
+
+  /* 
+   * check the SIM supports GID1 and GID2 
+   */
+  if (sim_check_service(15,sim_service_table) NEQ ALLOCATED_AND_ACTIVATED)
+    return MFW_SIM_FAILURE;
+
+  if (sim_check_service(16,sim_service_table) NEQ ALLOCATED_AND_ACTIVATED)
+    return MFW_SIM_FAILURE;
+
+	if (sim_blocked EQ TRUE OR
+      sim_clock   EQ SIMLOCK_BLOCKED)
+  {
+    /*
+     * Try to reset unlock attempt counter
+     */
+    sim_check_unblock_sim (&simlck);
+		return MFW_SIM_BLOCKED;
+  }
+
+  /*
+   * lock check disabled
+   */
+  if (sim_clock EQ SIMLOCK_DISABLED)
+    return MFW_SIM_DISABLE;
+
+  /*
+   * lock check blocked
+   */
+  if (sim_clock EQ SIMLOCK_LOCKED)
+    return MFW_SIM_LOCKED;
+
+  /*
+   * lock check enabled
+   */
+  if (sim_clock EQ SIMLOCK_ENABLED)            
+  {
+    if (sim_get_sim_lock (&simlck) NEQ PCM_OK)
+    {
+      TRACE_ERROR("No SIMLCK");
+      return MFW_SIM_FAILURE;     
+    }
+
+    /* 
+     * check SP group identifier 1 and 2 
+     */
+    if (simlck.gidl1 NEQ sim_config.sim_gidl1[0] OR 
+        simlck.gidl2 NEQ sim_config.sim_gidl2[0])
+    {
+      sim_clock     = SIMLOCK_LOCKED;
+  		simlck.locks2 = (UBYTE) FldSet(simlck.locks2,clock,sim_clock);
+ 	 		sim_set_sim_lock (&simlck);
+      return MFW_SIM_LOCKED;
+    }
+
+    /* 
+     * check all digits */
+		for (i=0; i<simlck.len_c_imsi; i++)
+		{
+			if (sim_check_imsi_digit(simlck.c_imsi[i], mfw_IMSI[i]) EQ FALSE)
+				break;
+		}
+
+    /*
+     * all digits okay
+     */
+		if (i EQ simlck.len_c_imsi)
+			return MFW_SIM_ENABLE;
+
+    /*
+     * C-Lock has failed
+     */
+    sim_clock     = SIMLOCK_LOCKED;
+		simlck.locks2 = (UBYTE) FldSet(simlck.locks2,clock,sim_clock);
+		sim_set_sim_lock (&simlck);
+
+    return MFW_SIM_LOCKED;
+  }
+  return MFW_SIM_FAILURE;
+}
+
+/*
++-----------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM               |
+| STATE   : code                        ROUTINE : sim_get_simlock_count |
++-----------------------------------------------------------------------+
+
+  PURPOSE : Request the count of SIMLOCK
+
+*/
+
+T_MFW sim_get_simlock_count(UBYTE *cnt)
+{
+  EF_SIMLCKEXT simlck;
+
+  TRACE_FUNCTION("sim_get_simlock_count()");
+
+  if (sim_get_sim_lock (&simlck) NEQ PCM_OK)
+    return MFW_SIM_FAILURE;
+  else
+    *cnt = simlck.cnt;
+  return MFW_SIM_SUCCESS;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_pin_status     |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request PIN1/PIN2 status
+
+*/
+
+void sim_pin_status(T_MFW_SIM_PIN_STATUS *status)
+{
+  SHORT           pn1Cnt;
+  SHORT           pn2Cnt;
+  SHORT           pk1Cnt;
+  SHORT           pk2Cnt;
+  T_ACI_PVRF_STAT ps1;
+  T_ACI_PVRF_STAT ps2;
+
+  TRACE_FUNCTION("sim_pin_status()");
+
+  status->stat = MFW_SIM_UNKNOWN;
+  status->set  = MFW_SIM_UNKNOWN;
+  if (qAT_PercentPVRF(CMD_SRC_LCL, &pn1Cnt, 
+                      &pn2Cnt, &pk1Cnt, &pk2Cnt, &ps1, &ps2) == AT_CMPL)
+  {
+    switch (status->type)
+    {
+      case MFW_SIM_PIN1:
+        status->stat = sim_cvtPINstatus(ps1, MFW_SIM_PIN1);
+        status->set = pin1_set;
+        break;
+      case MFW_SIM_PIN2:
+        status->stat = sim_cvtPINstatus(ps2, MFW_SIM_PIN2);
+        status->set  = pin2_set;
+        break;
+    }
+  }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_cvtPINstatus   |
++--------------------------------------------------------------------+
+
+  PURPOSE :
+
+*/
+
+UBYTE sim_cvtPINstatus(T_ACI_PVRF_STAT ps, UBYTE type)
+{
+  TRACE_FUNCTION("sim_cvtPINstatus()");
+
+  switch (ps)
+  {
+    case PVRF_STAT_NotRequired: 
+      return MFW_SIM_NO_PIN;
+    case PVRF_STAT_Required:
+      if (type EQ MFW_SIM_PIN1) 
+        return MFW_SIM_PIN_REQ;
+      if (type EQ MFW_SIM_PIN2) 
+        return MFW_SIM_PIN2_REQ;
+      return MFW_SIM_UNKNOWN;
+    default:                    
+      return MFW_SIM_UNKNOWN;
+  }
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : simDecodeIMSI      |
++--------------------------------------------------------------------+
+
+  PURPOSE : convert imsi (packed bcd to ASCIIZ; ->11.11)
+
+*/
+
+void simDecodeIMSI (UBYTE * imsi_field, 
+                    UBYTE   imsi_c_field, 
+                    UBYTE * imsi_extracted)
+{
+  UBYTE length;
+  UBYTE i;
+  UBYTE digit;
+
+  TRACE_FUNCTION ("simDecodeImsi()");
+
+  /*
+   * calculate number of digits
+   */
+  length = (imsi_c_field-1)*2;
+
+  /*
+   * if odd number of digits add one
+   */
+  if (imsi_field[0] & 0x08)
+    length++;
+
+  /*
+   * extract all digits
+   */
+  for (i = 0; i < length; i++)
+  {
+    digit = (i & 1) ?
+        imsi_field[(i + 1) / 2] & 0x0f :
+       (imsi_field[(i + 1) / 2] & 0xf0) >> 4;
+
+#if defined (WIN32)
+    {
+      char buf[40];
+      sprintf (buf, "DIGIT [%d] = %d",i, digit);
+      TRACE_FUNCTION (buf);
+    }
+#endif
+    if (i < LONG_NAME)
+      imsi_extracted [i] = digit + 0x30;
+    else
+    {
+      imsi_extracted [i] = 0;
+      return;
+    }
+  }
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_pin_ident      |
++--------------------------------------------------------------------+
+
+  PURPOSE : handle mfw windows command
+
+*/
+
+void sim_pin_ident(UBYTE id)
+{
+  TRACE_FUNCTION("sim_pin_ident()");
+  pin_ident = id;
+}
+
+/*
++-----------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)         MODULE  : MFW_SIM              |
+| STATE   : code                         ROUTINE : sim_check_imsi_digit |
++-----------------------------------------------------------------------+
+
+  PURPOSE : Check a IMSI digit
+
+*/
+
+T_MFW sim_check_imsi_digit(UBYTE pcm_imsi, UBYTE sim_imsi)
+{
+	UBYTE h;
+	UBYTE l;
+
+  TRACE_FUNCTION("sim_check_imsi_digit()");
+
+	h = pcm_imsi >> 4 | 0x30;
+	l = pcm_imsi & 0x0F | 0x30;
+
+#if defined (WIN32)
+  {
+    char buf[40];
+    sprintf (buf, "check %c shall be in the range [%c..%c]",
+             sim_imsi, h, l);
+    TRACE_FUNCTION (buf);
+  }
+#endif
+
+	if (h > l)
+		return FALSE;
+
+	if ((sim_imsi < h) OR (sim_imsi > l))
+		return FALSE;
+
+	return TRUE;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : simCommand         |
++--------------------------------------------------------------------+
+
+  PURPOSE : handle mfw windows command
+
+*/
+
+static int simCommand (U32 cmd, void *h)
+{
+    switch (cmd)
+    {
+        case MfwCmdDelete:              /* delete me                */
+            if (!h)
+                return 0;
+            sim_delete(h);
+            return 1;
+        default:
+            break;
+    }
+
+    return 0;
+}
+
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_get_sim_lock   |
++--------------------------------------------------------------------+
+
+  PURPOSE : Reads the SIM LOCK Record content from PCM
+
+*/
+
+#if defined (WIN32)
+static const UBYTE sim_lock_table_1 [] =
+{
+  //
+  // all locks enabled, wrong IMSI
+  //
+  0x55, 0x01,                // locks
+  0x00,                      // unblock counter
+  0x0F,                      // maximum attempt
+  0x21, 0x43, 0x65, 0x87,    // P control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // N control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // NS control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // SP control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // C control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x0F,                      // length of IMSI
+  0x22, 0x00, 0x22, 0x01,    // IMSI range definition
+  0x23, 0x15, 0x22, 0x35,
+  0x24, 0x25, 0x11, 0x22,
+  0x46, 0x55, 0x66,   
+  0x00,	0x00                 // Group Identifier
+};
+
+static const UBYTE sim_lock_table_2 [] =
+{
+  //
+  // all locks enabled, IMSI ok
+  //
+  0x55, 0x01,                // locks
+  0x00,                      // unblock counter
+  0x0F,                      // maximum attempt
+  0x21, 0x43, 0x65, 0x87,    // P control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // N control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // NS control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // SP control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // C control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x0D,                      // length of IMSI
+  0x22, 0x66, 0x22, 0x00,    // IMSI range definition
+  0x11, 0x44, 0x77, 0x09,
+  0x09, 0x09, 0x09, 0x09,
+  0x09, 0x09, 0x09,   
+  0x00,	0x00                 // Group Identifier
+};
+
+static const UBYTE sim_lock_table_3 [] =
+{
+  //
+  // all locks enabled, wrong IMSI, extended format
+  //
+  0x55, 0x01,                // locks
+  0x00,                      // unblock counter
+  0x0F,                      // maximum attempt
+  0x21, 0x43, 0x65, 0x87,    // P control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // N control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // NS control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // SP control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // C control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x0F,                      // length of IMSI P-Lock
+  0x22, 0x00, 0x22, 0x01,    // IMSI range definition P-Lock
+  0x23, 0x15, 0x22, 0x35,
+  0x24, 0x25, 0x11, 0x22,
+  0x46, 0x55, 0x66,   
+  0x0F,                      // length of IMSI SP-Lock
+  0x22, 0x00, 0x22, 0x01,    // IMSI range definition SP-Lock
+  0x23, 0x15, 0x22, 0x35,
+  0x24, 0x25, 0x11, 0x22,
+  0x46, 0x55, 0x66,   
+  0x0F,                      // length of IMSI NS-Lock
+  0x22, 0x00, 0x22, 0x01,    // IMSI range definition NS-Lock
+  0x23, 0x15, 0x22, 0x35,
+  0x24, 0x25, 0x11, 0x22,
+  0x46, 0x55, 0x66,   
+  0x0F,                      // length of IMSI C-Lock
+  0x22, 0x00, 0x22, 0x01,    // IMSI range definition C-Lock
+  0x23, 0x15, 0x22, 0x35,
+  0x24, 0x25, 0x11, 0x22,
+  0x46, 0x55, 0x66,   
+  0x0F,                      // length of IMSI N-Lock
+  0x22, 0x00, 0x22, 0x01,    // IMSI range definition N-Lock
+  0x23, 0x15, 0x22, 0x35,
+  0x24, 0x25, 0x11, 0x22,
+  0x46, 0x55, 0x66,   
+  0x0F,                      // length of IMSI U-Lock
+  0x22, 0x00, 0x22, 0x01,    // IMSI range definition U-Lock
+  0x23, 0x15, 0x22, 0x35,
+  0x24, 0x25, 0x11, 0x22,
+  0x46, 0x55, 0x66,   
+  0x00,	0x00                 // Group Identifier
+};
+
+static const UBYTE sim_lock_table_4 [] =
+{
+  //
+  // all locks enabled, IMSI ok, extended format
+  //
+  0x55, 0x01,                // locks
+  0x00,                      // unblock counter
+  0x0F,                      // maximum attempt
+  0x21, 0x43, 0x65, 0x87,    // P control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // N control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // NS control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // SP control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // C control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x0D,                      // length of IMSI P-Lock 
+  0x22, 0x66, 0x22, 0x00,    // IMSI range definition P-Lock
+  0x11, 0x44, 0x77, 0x09,
+  0x09, 0x09, 0x09, 0x09,
+  0x09, 0x09, 0x09,   
+  0x0D,                      // length of IMSI SP-Lock 
+  0x22, 0x66, 0x22, 0x00,    // IMSI range definition SP-Lock
+  0x11, 0x44, 0x77, 0x09,
+  0x09, 0x09, 0x09, 0x09,
+  0x09, 0x09, 0x09,   
+  0x0D,                      // length of IMSI NS-Lock 
+  0x22, 0x66, 0x22, 0x00,    // IMSI range definition NS-Lock
+  0x11, 0x44, 0x77, 0x09,
+  0x09, 0x09, 0x09, 0x09,
+  0x09, 0x09, 0x09,   
+  0x0D,                      // length of IMSI C-Lock 
+  0x22, 0x66, 0x22, 0x00,    // IMSI range definition C-Lock
+  0x11, 0x44, 0x77, 0x09,
+  0x09, 0x09, 0x09, 0x09,
+  0x09, 0x09, 0x09,   
+  0x0D,                      // length of IMSI N-Lock 
+  0x22, 0x66, 0x22, 0x00,    // IMSI range definition N-Lock
+  0x11, 0x44, 0x77, 0x09,
+  0x09, 0x09, 0x09, 0x09,
+  0x09, 0x09, 0x09,   
+  0x0D,                      // length of IMSI U-Lock 
+  0x22, 0x66, 0x22, 0x00,    // IMSI range definition U-Lock
+  0x11, 0x44, 0x77, 0x09,
+  0x09, 0x09, 0x09, 0x09,
+  0x09, 0x09, 0x09,   
+  0x00,	0x00                 // Group Identifier
+};
+
+static const UBYTE sim_lock_table_5 [] =
+{
+  //
+  // one lock enabled, wrong IMSI ok
+  //
+  0x01, 0x00,                // locks
+  0x00,                      // unblock counter
+  0x0F,                      // maximum attempt
+  0x21, 0x43, 0x65, 0x87,    // P control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // N control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // NS control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // SP control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x21, 0x43, 0x65, 0x87,    // C control key
+  0xFF, 0xFF, 0xFF, 0xFF,
+  0x0D,                      // length of IMSI
+  0x22, 0x00, 0x22, 0x00,    // IMSI range definition
+  0x11, 0x44, 0x77, 0x09,
+  0x09, 0x09, 0x09, 0x09,
+  0x09, 0x09, 0x09,   
+  0x00,	0x00                 // Group Identifier
+};
+
+#endif
+
+static UBYTE sim_get_sim_lock (EF_SIMLCKEXT * simlck)
+{
+  UBYTE version;
+  UBYTE sim_lock_type = 0;
+
+  TRACE_FUNCTION("sim_get_sim_lock()");
+
+#if defined (WIN32)
+  version = 0;
+
+  switch (sim_lock_mode)
+  {
+    case 1:
+      memcpy (simlck, sim_lock_table_1, SIZE_EF_SIMLCK);
+      sim_lock_field = 1;
+      sim_fill_sim_lock (simlck);
+      break;
+    case 2:
+      memcpy (simlck, sim_lock_table_2, SIZE_EF_SIMLCK);
+      sim_lock_field = 1;
+      sim_fill_sim_lock (simlck);
+      break;
+    case 3:
+      memcpy (simlck, sim_lock_table_3, SIZE_EF_SIMLCKEXT);
+      sim_lock_field = 2;
+      break;
+    case 4:
+      memcpy (simlck, sim_lock_table_4, SIZE_EF_SIMLCKEXT);
+      sim_lock_field = 2;
+      break;
+    case 5:
+      memcpy (simlck, sim_lock_table_5, SIZE_EF_SIMLCKEXT);
+      sim_lock_field = 1;
+      break;
+    default:
+      memset (simlck, 0, SIZE_EF_SIMLCKEXT);
+      sim_lock_field = 2;
+      break;
+  }
+  return PCM_OK;
+#else
+
+  if (sim_lock_field EQ NOT_PRESENT_8BIT)
+  {
+    if (pcm_ReadFile((UBYTE *) EF_SIMLCK_ID,
+                     SIZE_EF_SIMLCK,
+                     (UBYTE *) simlck,
+                     &version) EQ PCM_OK)
+    {
+      sim_lock_field = 1;
+      sim_fill_sim_lock (simlck);
+      return PCM_OK;
+    }
+    if (pcm_ReadFile((UBYTE *) EF_SIMLCKEXT_ID,
+                     SIZE_EF_SIMLCKEXT,
+                     (UBYTE *) simlck,
+                     &version) EQ PCM_OK)
+    {
+      sim_lock_field = 2;
+      return PCM_OK;
+    }
+    return PCM_NVRAM_ACCS_FAIL;
+  }
+
+  if (sim_lock_field EQ 1)
+  {
+    if (pcm_ReadFile((UBYTE *) EF_SIMLCK_ID,
+                     SIZE_EF_SIMLCK,
+                     (UBYTE *) simlck,
+                     &version) EQ PCM_OK)
+    {
+      sim_fill_sim_lock (simlck);
+      return PCM_OK;
+    }
+  }
+
+  if (sim_lock_field EQ 2)
+  {
+    if (pcm_ReadFile((UBYTE *) EF_SIMLCKEXT_ID,
+                     SIZE_EF_SIMLCKEXT,
+                     (UBYTE *) simlck,
+                     &version) EQ PCM_OK)
+    {
+      return PCM_OK;
+    }
+  }
+  return PCM_NVRAM_ACCS_FAIL;
+#endif
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_get_sim_lock   |
++--------------------------------------------------------------------+
+
+  PURPOSE : Reads the SIM LOCK Record content from PCM
+
+*/
+
+static void sim_set_sim_lock (EF_SIMLCKEXT * simlck)
+{
+  TRACE_FUNCTION("sim_set_sim_lock()");
+
+  if (sim_lock_field EQ 1)
+  {
+    /*
+     * set GDL1 and 2 on the expected location
+     * => len_sp_imsi = gdl1, sp_imsi[0] = gdl2
+     */
+    simlck->len_sp_imsi = simlck->gidl1;
+    simlck->sp_imsi [0] = simlck->gidl2;
+    pcm_WriteFile((UBYTE *) EF_SIMLCK_ID,SIZE_EF_SIMLCK,
+	  						  (UBYTE *) simlck);
+  }
+  else
+    pcm_WriteFile((UBYTE *) EF_SIMLCKEXT_ID,SIZE_EF_SIMLCKEXT,
+	  						  (UBYTE *) simlck);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_fill_sim_lock  |
++--------------------------------------------------------------------+
+
+  PURPOSE : Fills the extended SIM Lock record with defaults if
+            only the simple SIM Lock Record is available.
+
+*/
+
+static void sim_fill_sim_lock (EF_SIMLCKEXT * simlck)
+{
+  TRACE_FUNCTION("sim_fill_sim_lock()");
+
+  if (sim_lock_field EQ 1)
+  {
+    /*
+     * PCM contains SIMLOCK record. Must be mapped to the internal
+     * used SIMLOCKEXT record.
+     *
+     * gidl1, gidl2 to the end of record:
+     */
+    simlck->gidl1 = simlck->len_sp_imsi;
+    simlck->gidl2 = simlck->sp_imsi [0];
+    /*
+     * IMSI must be copied for the other locks
+     * N-Lock   digits 1..5, rest filled with 0x09 to suppress compare
+     * SP-Lock  digits 1..5, rest filled with 0x09 to suppress compare
+     * NS-Lock  digits 1..7, rest filled with 0x09 to suppress compare     
+     * C-Lock   digits 1..5, rest filled with 0x09 to suppress compare
+     */
+    memset (simlck->n_imsi, 0x09, 15);
+    memcpy (simlck->n_imsi, simlck->p_imsi, 5);
+    simlck->len_n_imsi = 5;
+    memset (simlck->sp_imsi, 0x09, 15);
+    memcpy (simlck->sp_imsi, simlck->p_imsi, 5);
+    simlck->len_ns_imsi = 5;
+    memset (simlck->ns_imsi, 0x09, 15);
+    memcpy (simlck->ns_imsi, simlck->p_imsi, 7);
+    simlck->len_ns_imsi = 7;
+    memset (simlck->c_imsi, 0x09, 15);
+    memcpy (simlck->c_imsi, simlck->p_imsi, 5);
+    simlck->len_c_imsi = 5;
+    /*
+     * initialise unblock imsi so that it never will fit
+     */
+    simlck->len_u_imsi = 0;
+  }
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)     MODULE  : MFW_SIM               |
+| STATE   : code                     ROUTINE : sim_check_unblock_sim |
++--------------------------------------------------------------------+
+
+  PURPOSE : Checks the IMSI against a stored unblock SIM. If the
+            check is positive, the unlock attempt counter will 
+            be resetted.
+            
+*/
+
+static void sim_check_unblock_sim (EF_SIMLCKEXT * simlck)
+{
+  UBYTE i;
+
+  TRACE_FUNCTION("sim_check_unblock_sim()");
+
+  if (sim_get_sim_lock (simlck) EQ PCM_OK)
+  {
+    if (simlck->len_u_imsi EQ 0)
+      return;
+
+    /* 
+     * check all digits */
+	  for (i=0; i<simlck->len_u_imsi; i++)
+    {
+  	  if (sim_check_imsi_digit(simlck->u_imsi[i], mfw_IMSI[i]) EQ FALSE)
+		    break;
+    }
+
+    /*
+     * all digits okay, then reset counter and nothing else
+     */
+	  if (i EQ simlck->len_u_imsi)
+    {
+  	  simlck->cnt = 0;
+	    sim_set_sim_lock (simlck);
+    }
+  }
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)     MODULE  : MFW_SIM               |
+| STATE   : code                     ROUTINE : sim_simlock_ok        |
++--------------------------------------------------------------------+
+
+  PURPOSE : The function checks whether the SIM LOCK is active or not.
+            
+*/
+
+UBYTE sim_simlock_ok (void)
+{
+  if (sim_nslock EQ SIMLOCK_BLOCKED OR
+      sim_nslock EQ SIMLOCK_LOCKED)
+    return FALSE;
+
+  if (sim_plock EQ SIMLOCK_BLOCKED OR
+      sim_plock EQ SIMLOCK_LOCKED)
+    return FALSE;
+
+  if (sim_splock EQ SIMLOCK_BLOCKED OR
+      sim_splock EQ SIMLOCK_LOCKED)
+    return FALSE;
+
+  if (sim_nlock EQ SIMLOCK_BLOCKED OR
+      sim_nlock EQ SIMLOCK_LOCKED)
+    return FALSE;
+
+  if (sim_clock EQ SIMLOCK_BLOCKED OR
+      sim_clock EQ SIMLOCK_LOCKED)
+    return FALSE;
+
+  return TRUE;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)        MODULE  : MFW_SIM            |
+| STATE   : code                        ROUTINE : sim_get_imsi       |
++--------------------------------------------------------------------+
+
+  PURPOSE : Request IMSI number in SIM card
+
+*/
+
+UBYTE * sim_get_imsi (void)
+{
+  return mfw_IMSI;
+}
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)   MODULE  : MFW_SIM                  |
+| STATE   : code                   ROUTINE : sim_mmi_update_parameter |
++---------------------------------------------------------------------+
+
+  PURPOSE : MMI relevant parameters from the SIM card
+
+*/
+
+void sim_mmi_update_parameter(T_SIM_ACTIVATE_IND *sim_act_ind)
+{
+  TRACE_FUNCTION("sim_mmi_update_parameter()");
+
+  memcpy( sim_config.pref_lang, sim_act_ind->pref_lang, 5);
+}
+
+#ifdef SIM_TOOLKIT
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)   MODULE  : MFW_SIM                  |
+| STATE   : code                   ROUTINE : sim_sat_file_update      |
++---------------------------------------------------------------------+
+
+  PURPOSE : SIM file change indication
+
+*/
+
+void sim_sat_file_update(USHORT dataId)
+{
+  TRACE_FUNCTION("sim_sat_file_update()");
+
+  sat_update = TRUE;
+  switch (dataId)
+  {
+    case SIM_SST:
+      sim_read_sim(SIM_SST, NOT_PRESENT_8BIT, 10);
+      break;
+    case SIM_GID1:
+      sim_read_sim(SIM_GID1, NOT_PRESENT_8BIT, 5);
+      break;
+    case SIM_GID2:
+      sim_read_sim(SIM_GID2, NOT_PRESENT_8BIT, 5);
+      break;
+    default:
+      break;
+  }
+}
+#endif
+
+/*
++---------------------------------------------------------------------+
+| PROJECT : MMI-Framework (8417)   MODULE  : MFW_SIM                  |
+| STATE   : code                   ROUTINE : sim_read_sst_cnf         |
++---------------------------------------------------------------------+
+
+  PURPOSE : SIM file change indication
+
+*/
+
+void sim_read_sst_cnf (SHORT error, UBYTE *data)
+{
+  TRACE_FUNCTION("sim_read_sst_cnf()");
+
+  if (error EQ SIM_NO_ERROR)
+    memcpy(sim_service_table, data, sizeof(sim_service_table));
+  else
+    TRACE_EVENT("SST read error");
+
+#ifdef SIM_TOOLKIT
+  if (sat_update)
+  {
+    sat_update = FALSE;
+    satUpdateFiles ( TRUE, SIM_SST );
+  }
+#endif
+}