view src/ui/bmi/mmiStart.c @ 303:f76436d19a7a default tip

!GPRS config: fix long-standing AT+COPS chance hanging bug There has been a long-standing bug in FreeCalypso going back years: sometimes in the AT command bring-up sequence of an ACI-only MS, the AT+COPS command would produce only a power scan followed by cessation of protocol stack activity (only L1 ADC traces), instead of the expected network search sequence. This behaviour was seen in different FC firmware versions going back to Citrine, and seemed to follow some law of chance, not reliably repeatable. This bug has been tracked down and found to be specific to !GPRS configuration, stemming from our TCS2/TCS3 hybrid and reconstruction of !GPRS support that was bitrotten in TCS3.2/LoCosto version. ACI module psa_mms.c, needed only for !GPRS, was missing in the TCS3 version and had to be pulled from TCS2 - but as it turns out, there is a new field in the MMR_REG_REQ primitive that needs to be set correctly, and that psa_mms.c module is the place where this initialization needed to be added.
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 08 Jun 2023 08:23:37 +0000
parents 053ff6a94961
children
line wrap: on
line source

/*******************************************************************************

			CONDAT (UK)

********************************************************************************

 This software product is the property of Condat (UK) Ltd and may not be
 disclosed to any third party without the express permission of the owner.

********************************************************************************

 $Project name:	Basic MMI
 $Project code:	BMI (6349)
 $Module:	Start
 $File:		MmiStart.c
 $Revision:	1.0

 $Author:	Condat(UK)
 $Date:		25/10/00

********************************************************************************

 Description:

    This provides the start code for the MMI

********************************************************************************
 $History: MmiStart.c

	Jan 05, 2007 OMAPS00084665  x0039928(sumanth)
 	Description: Boot time exceed UCSD estimations

 	xashmic 21 Sep 2006, OMAPS00095831
 	Description: USB enumeration does not happen in PIN/PUK/Insert SIM scenarios
 	Solution: When booting up without SIM card, or prompting for PIN/PUK/SIMP entry,
 	enumerate all the USB ports automatically

       May 30, 2006 REF:OMAPS00079650  a0393213 (R.Prabakar)
       Description : CPHS Call Forwarding feature implementation
       Solution     : As part of the implemention, in this file, divert status is got immediately after boot-up

	Apr 06, 2006    ERT: OMAPS00070660 x0039928(sumanth)
   	Description: Need to reduce flash foot-print for Locosto Lite
   	Solution: Voice Memo feature is put under the flag #ifndef FF_NO_VOICE_MEMO to compile
   	out voice memo feature if the above flag is enabled.

 	Oct 11, 2005	REF: LOCOSTO-SPR-34629	-	xpradipg
 	Description:	Temporary removal of animation logo and replacing with
 			static image
 	Solution:	The Animation at bootup is removed and replaced with a static
 			image also the display of logo is done before initiating the
 			AT_CMD_CFUN full functionality

    	Jun 23, 2004   	REF: CRR MMI-SPR-13599  Rashmi C N(Sasken)
  	Solution:	The CF state is maintained in flash. During bootup the CF icon in the idle screen
  			is displayed depending upon its state in the ffs

	25/10/00	Original Condat(UK) BMI version.

	Dec 23, 2005 REF: SR13873 - x0020906
	Description : Store the FFS value into current sound structure
	Fix : Call setDefaultSound () to assign FFS value into current sound structure.

 $End

*******************************************************************************/


/*******************************************************************************

                                Include files

*******************************************************************************/
#define ENTITY_MFW

//#define CO_UDP_IP temp till xml file ready

/* includes */
#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 "mfw_sys.h"
#include "prim.h"
#include "pwr.h" /*OMAPS00091029 x0039928(sumanth)*/

#include "mfw_mfw.h"
#include "mfw_win.h"
#include "mfw_kbd.h"
/* SPR#1428 - SH - New Editor changes */
#ifndef NEW_EDITOR
#include "mfw_edt.h"
#endif
#include "mfw_icn.h"
#include "mfw_mnu.h"

#include "mfw_lng.h"
#include "mfw_nm.h"
#include "mfw_icn.h"
#include "mfw_sim.h"
#include "mfw_sat.h"
#include "mfw_phb.h"
#include "ksd.h"
#include "psa.h"
#include "mfw_sms.h"
#include "mfw_tim.h"
#include "mfw_mme.h" 	// SH - so we can call mmeInit in show_welcome_cb

#include "MmiMmi.h"
#include "MmiDummy.h"
#include "MmiDialogs.h"
#include "MmiLists.h"

#include "MmiMain.h"
#include "mmiCall.h"
#include "MmiStart.h"
#include "MmiPins.h"
#include "MmiIdle.h"
#include "Mmiicons.h"
#include "MmiSettings.h"
#include "MmiMenu.h"
#include "MmiNetwork.h"
#include "MmiServices.h"
#include "MmiBookController.h"
#include "MmiBookServices.h"
#include "MmiNetwork.h"
#include "MmiSimToolkit.h"

#ifndef FF_NO_VOICE_MEMO
#include "MmiVoiceMemo.h"
#endif

#include "MmiCPHS.h"
#include "mmiSmsIdle.h"
#include "mmiSmsMenu.h"

/* Set Default FFS value to sound structure - RAVI - 23-12-2005 */
#ifdef NEPTUNE_BOARD
#include "MmiSounds.h"
#endif
/* END RAVI */

#ifdef BTE_MOBILE
#include "mmiBluetooth.h"
#endif

#ifdef MMI_GPRS_ENABLED
#include "MmiGprs.h"
#endif /* GPRS */

/* SPR759 - SH*/
#ifdef MMI_HOMEZONE_ENABLED
#include "MmiHomezone.h"
#endif

/* SPR1983 - SH */
#ifdef FF_WAP
#include "MmiWapFfs.h"

/* SPR2086 - SH */
#include "AUIWapext.h"
#endif

#ifndef NEPTUNE_BOARD
#ifdef FF_EM_MODE
#include "MmiEm.h"
#endif
#else
#ifdef TI_PS_FF_EM
#include "MmiEm.h"
#endif
#endif

#include "cus_aci.h"

#include "prim.h"
#ifndef PCM_2_FFS
#include "pcm.h"
#endif


#include "mmiColours.h"

#ifndef MFW_EVENT_PASSED
#define MFW_EVENT_PASSED 0
#endif

// Jun 23 2004        REF: CRR MMI-SPR-13599  Rashmi C N(Sasken)
#include "mfw_ffs.h"

#ifdef FF_MMI_MULTIMEDIA
#include "mfw_MultimediaApp.h"
#endif


extern void sms_cb_init (void);

/*******************************************************************************

                                Static data

*******************************************************************************/

static MfwHnd win;
static MfwHnd kbd;

/* The following information controls the welcome animation
*/
#define WELCOME     1
#define NO_WELCOME  0

/* static MfwHnd win_animation;  x0039928 - Lint warning fix */
/* static USHORT animation_index; x0039928 - Lint warning fix */
/* static U8 welcome_status; x0039928 - Lint warning fix */
/* SPR877 - SH - set to TRUE if welcome animation has finished */
UBYTE animation_complete = FALSE;

/*******************************************************************************

                                Local prototypes

*******************************************************************************/

static int winEvent( MfwEvt e, MfwWin *w );
static int keyEvent( MfwEvt e, MfwKbd *k );


static void showDefault( void );

/* SH - moved showwelcome primitive to header file */
static int show_welcome_cb(T_MFW_HND win, USHORT identifier, UBYTE reason);
// 	Oct 11, 2005	REF: LOCOSTO-SPR-34629	-	xpradipg
#ifdef TI_PS_UICC_CHIPSET_15
extern unsigned char TIlogColour[];
#endif
/*******************************************************************************

                                Private methods

*******************************************************************************/

/*******************************************************************************

 $Function:    	startregis

 $Description:	All we need to do here is start the SIM

 $Returns:	None.

 $Arguments:	None.

*******************************************************************************/

static void startregis( void )
{
	TRACE_FUNCTION("start registration");
// 	Oct 11, 2005	REF: LOCOSTO-SPR-34629	-	xpradipg
//	the static image is displayed just before intiating the full functionality
#ifdef TI_PS_UICC_CHIPSET_15
	dspl_BitBlt2(WELCOME_ANI_POS_X, WELCOME_ANI_POS_Y,176,60,(char *)&TIlogColour[0],0,ICON_TYPE_256_COL);
#endif
	sim_activate();
}

/*******************************************************************************

                                Public methods

*******************************************************************************/

/*******************************************************************************

 $Function:    	startInit

 $Description:	Initialises the MMI startup functions

 $Returns:	None.

 $Arguments:	None.

*******************************************************************************/

void startInit( void )
{
#ifdef FF_MMI_MMS
    /* TISHMMS Project */
    extern void mms_wap_data_init(void);
    extern  void mms_mms_data_init(void);
#endif

//    T_MFW_HND hnd;   // RAVI

    /* Assume the welcome status is welcome
    */
    /* welcome_status = WELCOME;  x0039928 - Lint warning fix */

    animation_complete = FALSE;

    /* unset the flag for ready state at the beginning*/
    smsidle_unset_ready_state();

    /* setup signalling and AUTOFOCUS
    */
    mfwSetSignallingMethod( 1 );
    winAutoFocus( TRUE );

    /* API/GW - Set Colour of displays */
    colour_initial_colours();

    /* GW-SPR#1035-Added SAT changes by Nebi (changed initialisation order). */
    /* initialise network services */
    simToolkitInit( 0 );
    bookInitialise( 0 );
    callInit( 0 );
    iconsInit();

#ifdef BTE_MOBILE
    mmi_bt_init();
#endif

    /* Handlers created on windows */
    pin_init( 0 );
    networkInit( 0 );
    smsidle_start(0, NULL);
    servicesInit( 0 );

    idleInit( 0 );

#ifndef FF_NO_VOICE_MEMO
    voice_memo_init ();
#endif

    voice_mail_init ();
    sms_cb_init ();

    mmi_cphs_init();

    /* SPR#2346 - SH - GPRS */
#ifdef MMI_GPRS_ENABLED
    GPRS_Init();
#endif /* GPRS */

#ifndef NEPTUNE_BOARD
#ifdef FF_EM_MODE
    mmi_em_init();/*MC SPR1209 engineering mode*/
#endif

        /* SPR#2086 - SH - Startup WAP */
#if defined (FF_WAP) && defined (FF_GPF_TCPIP)
        AUI_wap_init();
#endif

#ifdef FF_MMI_MMS
            /* TISHMMS Project */
            /*init mms wap profile*/
            mms_wap_data_init();
            mms_mms_data_init();
#endif
#else /* NEPTUNE_BOARD */
/* NEPTUNE: Sumit*/
#if 0
	/* SPR#2346 - SH - GPRS */
#ifdef MMI_GPRS_ENABLED
	GPRS_Init();
#endif /* GPRS */

#ifdef TI_PS_FF_EM
	mmi_em_init();/*MC SPR1209 engineering mode*/
#endif

        /* SPR#2086 - SH - Startup WAP */
#if defined (FF_WAP) && defined (FF_GPF_TCPIP)
        AUI_wap_init();
#endif

#ifdef FF_MMI_MMS
            /* TISHMMS Project */
            /*init mms wap profile*/
            mms_wap_data_init();
            mms_mms_data_init();
#endif
#endif /* if 0 */
#endif /* NEPTUNE_BOARD */

/* Set FFS value into sound structure - RAVI - 21-12-2005 */
#ifdef NEPTUNE_BOARD
	setDefaultSound();
#endif
/* END RAVI - 21-12-2005 */

/* Retrive the configurable ring tone stored */
#ifdef NEPTUNE_BOARD
#ifdef FF_MMI_MULTIMEDIA
       Store_Default_Parameter ();
       setDefaultMSLTone ();
#endif
#endif
/* End */
	//xashmic 21 Sep 2006, OMAPS00095831
	//During bootup, PIN, PUK, SIMP, Insert SIM stages,
	//Audio module, USB module needs to be initialized for
	//Emergency call , USB enumeration respectively
	mmeInit();  //fieldstrength driver
	/* SH - PIN screen now comes before welcome screen */
	startregis();
}

/*******************************************************************************

 $Function:    	startExit

 $Description:	Stops the MMI start windows, basically reverses the effect
		of the startInit above

 $Returns:	None.

 $Arguments:	None.

*******************************************************************************/

void startExit( void )
{
    /* remove keyboard handlers
    */
    kbdDelete(kbd);
    kbd = 0;

    /* SPR#2346 - SH - GPRS */
    #ifdef MMI_GPRS_ENABLED
    GPRS_Exit();
    #endif /* GPRS */


    /* shut down the sim toolkit
    */
    simToolkitExit();

    /* close the phonebook, calls, idle, services, icons, sounds
       and network handlers
    */
    bookExit();

#ifdef BTE_MOBILE
    mmi_bt_exit();
#endif

    callExit();
    idleExit();
    smsidle_destroy ();
    iconsExit();
    cphs_exit(); //MC
#ifdef NEPTUNE_BOARD
#ifdef TI_PS_FF_EM
    mmi_em_exit();/*MC, SPR1209 engineering mode */
#endif
#else
#ifdef FF_EM_MODE
    mmi_em_exit();/*MC, SPR1209 engineering mode */
#endif
#endif
}

/*******************************************************************************

 $Function:    	startExec

 $Description:	start window execute method

 $Returns:	None.

 $Arguments:	reason, for invoking the execute method,
		next, not used passed for compatibility

*******************************************************************************/

void startExec( int reason, MmiState next )
{
    switch (reason)
    {
		case PhoneInit:
		{
			/* initialising, run the animation
			*/
		    sim_init();                     /* init SIM handler         */
		    nm_init();                      /* init REG handler         */
	    	startInit();                        /* init startup module      */

		}
        break;

		case FirstTimeNMFound:
		{
			/* first time through setup window and idle handlers
			*/
			TRACE_EVENT("NM Found");

			winFocus( win );
			winShow( win );
			idleExec( IdleNormal, 0 );

		}
		break;

		case NmSearching:
		{
			/* just trace on the search event for now
			*/
			TRACE_EVENT("Search");

		}
		break;

		default:
		{
			/* no default handling
			*/
			break;
		}
    }
}

/*******************************************************************************

 $Function:    	startWhoIsFocused

 $Description:	provides handle of currently focussed window

 $Returns:	mfwFocus

 $Arguments:	None.

*******************************************************************************/

MfwHnd startWhoIsFocused( void )
{
    return( mfwFocus );
}

/*******************************************************************************

 $Function:    	showwelcome

 $Description:	shows a welcome Message when swiching on the mobile

 $Returns:	none

 $Arguments:

*******************************************************************************/

void showwelcome (T_MFW_HND win)			/* SH - not static, as now externally called */
{
    TRACE_FUNCTION("showwelcome ()");

    idle_set_starting_up(FALSE); /*SPR#1662-NH Starting is finished for Idle */
// 	Oct 11, 2005	REF: LOCOSTO-SPR-34629	-	xpradipg
//	Since the static image is displayed at bootup and it is preponed, this
//	function will be called after the sim insert indication is recieved hence
//	we go ahead with the display of the Idle screen by calling show_welcome_cb

#if 0	/* FreeCalypso */
 boot_time_snapshot(EAppInit); /*OMAPS00091029 x0039928(sumanth) - to mark the end of app init*/
#endif
 TRACE_EVENT("Boot Time Snapshot - EAppInit");
#ifdef TI_PS_UICC_CHIPSET_15
	show_welcome_cb(win,0,0);
#else
{
	T_DISPLAY_DATA   display_info;
	dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtNull, TxtNull , COLOUR_STATUS_WELCOME);
	dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)show_welcome_cb, FOUR_SECS, 0 );

      /*
       * Call Icon
       */
	mmi_dialogs_insert_animation (info_dialog (win, &display_info), 400 ,(MfwIcnAttr*)&welcome_Attr,animwelcome);
}
#endif


}

/*******************************************************************************

 $Function:    	show_welcome_cb

 $Description:	shows a welcome Message when swiching on the mobile

 $Returns:	none

 $Arguments:

*******************************************************************************/

static int show_welcome_cb(T_MFW_HND win, USHORT identifier, UBYTE reason)
{
	TRACE_FUNCTION("show_welcome_cb");

   	/* SH - removed call to startregis, now in startInit */

    /* SPR759 - SH. Initialise homezone */
#ifdef MMI_HOMEZONE_ENABLED
   	homezoneInit();
#endif /* HOMEZONE */

	/* SPR#1983 - SH - Initialise flash files for WAP */

#if defined (FF_WAP) && defined (CO_UDP_IP)
	flash_wap_init();
#endif /* WAP */

	/* SPR#1112 - SH - Check which phonebook is active.  If FFS is formatted and
	 * FFS phonebook is selected, initialise it. */
#ifndef NEPTUNE_BOARD
#ifdef INT_PHONEBOOK
	bookInitInternal();
#endif
#else
#ifdef INT_PHONEBOOK
	// bookInitInternal(); //SUMIT: Neptune: removed call to bookInitInternal for FFS
#endif
#endif

	/* SPR#1352 - SH - Initialise TTY */
#ifdef MMI_TTY_ENABLED
	call_tty_init();
#endif
	/* end SH */

	animation_complete = TRUE;

    /* SPR#1929 - DS - Check if there is voicemail waiting. Port of 1960 */
	/*a0393213 cphs rel4*/
   #ifdef FF_CPHS_REL4
   if(!isMWISFilePresent())
   #endif
    GetCphsVoicemailStatus(0);

	/* 30th May,2006     OMAPS00079650     a0393213 (R.Prabakar)
           Description : CPHS Call Forwarding feature implementation
           Solution     : As part of the implemention, divert status is got during boot-up.
                             The existing code is also maintained*/
   #ifdef FF_CPHS
   /*a0393213 cphs rel4*/
   /* call cphs_get_divert_status() only when EF(CFIS) is not present. when EF(CFIS) is present, the call to
       cphs_get_divert_status() should be made only after fetching MSP information from network*/
   #ifdef FF_CPHS_REL4
   if(!isCFISFilePresent())
   #endif
	cphs_get_divert_status ();
   #else
	   //  Jun 23, 2004        REF: CRR MMI-SPR-13599  Rashmi C N(Sasken)
	//        Setting the CF icon state depending on the value in flash.
		if(FFS_flashData.CFState==TRUE)
		{
			iconsSetState(iconIdCallFor);
		}
		else
		{
			iconsDeleteState(iconIdCallFor);
		}
    #endif

    idleEvent(IdleUpdate);

	return 1;  // RAVI - Changed Return to Return 1
}

/* GW return when animation is complete (and the idle screen can be displayed*/
int mmiStart_animationComplete( void )
{
	return (animation_complete);
}


#ifdef NEW_KEY_INPUT
#include "kpd_cfg.h"
#include "mfw_kbd.h"
#define MAX_KEY 255
U32 mfw_kbd_map [MAX_KEY] =
{
	KEY_0,
	KEY_1,
	KEY_2,
	KEY_3,
	KEY_4,
	KEY_5,
	KEY_6,
	KEY_7,
	KEY_8,
	KEY_9,
	KEY_STAR,
};

void mfw_keyMap(int mfw_key, int hw_key)
{
	if ((hw_key >0) && (hw_key<MAX_KEY))
		mfw_kbd_map[hw_key] = mfw_key;
}

void start_setKeys( void )
{
	mfw_keyMap(KEY_0,		KPD_KEY_0);
	mfw_keyMap(KEY_1,		KPD_KEY_1);
	mfw_keyMap(KEY_2,		KPD_KEY_2);
	mfw_keyMap(KEY_3,		KPD_KEY_3);
	mfw_keyMap(KEY_4,		KPD_KEY_4);
	mfw_keyMap(KEY_5,		KPD_KEY_5);
	mfw_keyMap(KEY_6,		KPD_KEY_6);
	mfw_keyMap(KEY_7,		KPD_KEY_7);
	mfw_keyMap(KEY_8,		KPD_KEY_8);
	mfw_keyMap(KEY_9,		KPD_KEY_9);
	mfw_keyMap(KEY_STAR,	KPD_KEY_STAR);
	mfw_keyMap(KEY_HASH,	KPD_KEY_DIESE);
	mfw_keyMap(KEY_LEFT,	KPD_KEY_SOFT_LEFT);
	mfw_keyMap(KEY_RIGHT,	KPD_KEY_SOFT_RIGHT);
	mfw_keyMap(KEY_CALL,	KPD_KEY_CONNECT);
	mfw_keyMap(KEY_HUP,		KPD_KEY_DISCONNECT);
	mfw_keyMap(KEY_POWER,	KPD_PWR);

	mfw_keyMap(KEY_VOLUP,		KPD_KEY_VOL_UP);
	mfw_keyMap(KEY_VOLDOWN,		KPD_KEY_VOL_DOWN);

	mfw_keyMap(KEY_MNUUP,		KPD_KEY_UP);
	mfw_keyMap(KEY_MNUDOWN,		KPD_KEY_DOWN);
	mfw_keyMap(KEY_MNULEFT,		KPD_KEY_LEFT);
	mfw_keyMap(KEY_MNURIGHT,	KPD_KEY_RIGHT);
}

#endif

/*******************************************************************************

                                End of File

*******************************************************************************/