FreeCalypso > hg > fc-magnetite
diff src/aci2/bmi/ATBWapACI.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/bmi/ATBWapACI.c Mon Sep 26 00:29:36 2016 +0000 @@ -0,0 +1,3981 @@ +/******************************************************************************* + + 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: + $Project code: + $Module: + $File: ATBWapACI.c + $Revision: + + $Author: Condat(UK) + $Date: + +******************************************************************************** + + Description: + Provides an interface between the ATB and the ACI. + + +******************************************************************************** + + $History: ATBWapACI.c + + x0035544Nov 29, 2005 REF: MMI-SPR-33833(OMAPS00055207) + MMI making Riviera calls without using proper header files. So added appropriate header files. + + xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + Displaying of error message when image decoding fails + + xrashmic 30 Aug, 2005 MMI-SPR-34024(OMAPS00048918) mem leak fix + Freeing ImageReq data in WAP memory only for plugin images. + + Nov 02, 2005 DR OMAPS00052132 xdeepadh + Bug:Not able to access the SMS inbox and also not able to send SMS in Locosto Lite build + Fix: The ATI Enums usage has been put under the FF_ATI flag. + + xrashmic 17 Aug, 2005 MMI-SPR-31364 + When it is detected that a very large page is being opened, the wap adapter sends a message. + We need to exit wap and display a error dialog as we have memory constraints. + + xreddymn Jun-29-2005 MMI-ENH-32467: + Handling of animated GIF images + + July 18 2005 REF: MMI-SPR-32012 x0012849 + To change the functionality of RSK , when there is no page to go back. + + xrashmic 29 Jun, 2005 MMI-SPR-32462 + Patch given by Kyle for display of table border + + xreddymn Jun-21-2005 MMI-SPR-30291: Send one message for the entire profile, + instead of sending one parameter at a time, to the WAP adapter + + xreddymn May-15-2005 MMI-SPR-30962: Added changes to maintain WAP busy state + during MMS transactions. + + xreddymn May-14-2005 MMI-SPR-30834: added send memory free indication + from MMI to WAP + + xrashmic 12 May, 2005 MMI-SPR-30834 + For input text box, adding of [] is moved from wap adapter to bmi + + xreddymn Mar-22-2005 MMI-SPR-29767 + Modified behaviour of SL push message handling in MMI + + xreddymn Mar-11-2005 MMI-SPR-29510 + Enabled listing of SL WAP push messages + + xreddymn Mar-05-2005 MMI-SPR-26144 + Disabled dialog boxes that affect MMS send display + + xrashmic 08 Feb, 2005 MMI-SPR-27853 + Error handling in sending MMS and also displaying the progress value + + xreddymn Mar-11-2005 MMI-SPR-29510 + Enabled listing of SL WAP push messages + + Jan-24-2005 MMI-SPR-28135 - xreddymn: WAP_OTA settings saved in WAP profiles + + xrashmic 21 Jan, 2005 MMI-SPR-28223 + Saving the information passed by wap adapter if the image is from plugin or normal wap page. + + Dec-10-2003 MMI-SPR-26159 - xreddymn: Prevent duplicate entries in History List + + 15/05/2003 - SPR#1983 - SH - Updated to latest from 1.6.3 version. + + $End + +*******************************************************************************/ + + + +#ifndef PSA_WAPS_C +#define PSA_WAPS_C +#endif + +#ifdef MFW +#define ENTITY_MFW +#else +#ifdef SMI +#define ENTITY_SMI +#else +#define ENTITY_ACI +#endif +#endif + +#define ACI_MEMBER + +/*==== INCLUDES ===================================================*/ + +#include <stdio.h> +#include <string.h> +#include <stdlib.h> + +#include "typedefs.h" +#include "pconst.cdg" +#include "mconst.cdg" +#include "message.h" +#include "ccdapi.h" +#include "vsi.h" +#include "custom.h" +#include "gsm.h" +#include "prim.h" +#include "cnf_aci.h" +#include "mon_aci.h" +#include "pei.h" +#include "tok.h" +#include "message.h" +#include "prim.h" +#include "aci_cmh.h" +#include "ati_cmd.h" +#include "aci_cmd.h" + +/* BEGIN ADD: Sumit : Req ID: : 31-Mar-2005*/ +#ifndef NEPTUNE_BOARD +/* END ADD: Sumit : Req ID: : 31-Mar-2005*/ +#include "ffs/ffs.h" +/* BEGIN ADD: Sumit : Req ID: : 31-Mar-2005*/ +#else +#include "ffs.h" +#endif +/* END ADD: Sumit : Req ID: : 31-Mar-2005*/ + +#ifdef FF_GPF_TCPIP +#include "leconfig.h" +#include "capimic.h" +#include "aapimic.h" + + +#include "wapmic_types.h" +#include "wapmic_codec.h" +#else +#include "gledef.h" +#include "capiclnt.h" +#include "aapiclnt.h" + +#include "wap_types.h" +#include "wap_codec.h" +#endif + + +#include "ATBData.h" +#include "ATBWapACI.h" + +#include "ATBWapAUI.h" +#include "dspl.h" + +#ifdef GPRS +#include "gaci_cmh.h" +#endif + +//x0035544 29 Nov, 2005 MMI-SPR-55207 +#ifndef NEPTUNE_BOARD //x0035544 Sudha - Guarded the below header files for Neptune. +#include "rvf/rvf_api.h" // for the function rvf_delay() +#endif +#ifdef FF_GPF_TCPIP +#include "tapimmi.h" + +#include "socket_api.h" +#include "wapmic_sdlh.h" + +// xreddymn Jan-24-2005 MMI-SPR-28135: WAP_OTA settings saved in WAP profiles +#include "mfw_ss.h" // For definitions of MFW_ASCII, MFW_DCS_UCS2 + +int ATB_convert_String( char * ipString, UBYTE ipDataType, int ipLength, + char * opString, UBYTE opDataType, int opLength, UBYTE addNull); +void ATB_wap_profile_add(T_WAP_PROFILE *p); + +#endif + + +EXTERN char *atD (char *cl,UBYTE srcId); + +//xrashmic 21 Jan, 2005 MMI-SPR-28223 + +/******************************************************************************* + + $Function: M_MMI_WAP_READY_IND + + $Description: Indicate to WAP that MMI is ready to receive events + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + + +void M_MMI_WAP_READY_IND(T_MMI_WAP_READY_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_READY_IND"); +#endif + + mmi_coder(WAP_READY_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_START_IND + + $Description: Tell WAP Browser to start up + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +#ifdef CO_UDP_IP +void M_MMI_WAP_START_IND(T_MMI_WAP_START_IND *parameter) +#else +void M_MMI_WAP_START_IND(T_MMI_WAP_START_USER_AGENT_REQ *parameter) +#endif +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_START_IND"); +#endif + + mmi_coder(WAP_START_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_NEW_VIEW_IND + + $Description: Tell WAP Browser to start a new view + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + + +void M_MMI_WAP_NEW_VIEW_IND(T_MMI_WAP_NEW_VIEW_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_NEW_VIEW_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P2("id/uamode: %d, %d", parameter->object_id, parameter->uaMode); + TRACE_EVENT_P2("width/height: %d, %d", parameter->view_width, parameter->view_height); + TRACE_EVENT_P2("font height: %d, width of 'A': %d", parameter->font_height, parameter->font_width[65]); + TRACE_EVENT_P2("unicode height: %d, unicode width: %d", parameter->unicode_width, parameter->unicode_height); +#endif + + mmi_coder(WAP_NEW_VIEW_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_TERMINATE_IND + + $Description: Tell WAP Browser to terminate. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_TERMINATE_IND(T_MMI_WAP_TERMINATE_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_TERMINATE_IND"); +#endif + + mmi_coder(WAP_TERMINATE_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_CLOSE_VIEW_IND + + $Description: Close the specified view. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CLOSE_VIEW_IND(T_MMI_WAP_CLOSE_VIEW_IND *parameter) +{ +#ifdef TRACE_WAP_WAPMMI + TRACE_FUNCTION("M_MMI_WAP_CLOSE_VIEW_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + mmi_coder(WAP_CLOSE_VIEW_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_CONFIGURE_IND + + $Description: Send configuration information to WAP Browser + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONFIGURE_IND(T_MMI_WAP_CONFIGURE_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONFIGURE_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P3( "Type, Param, Length: %d, %d, %d", parameter->type, parameter->param, parameter->length); + TRACE_EVENT_P1( "Integer Value: %d", parameter->intvalue); + if (parameter->length>0) + ATB_trace_string(parameter->strvalue, parameter->length); +#endif + + mmi_coder(WAP_CONFIGURE_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_CONNECTION_CONFIGURE_IND + + $Description: Send configuration information to WAP Browser + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONNECTION_CONFIGURE_IND(T_MMI_WAP_CONNECTION_CONFIGURE_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONNECTION_CONFIGURE_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P3( "Type, Channel_id, Length: %d, %d, %d", parameter->type, parameter->channel_id, parameter->length); + TRACE_EVENT_P1( "Integer Value: %d", parameter->intvalue); + ATB_trace_string(parameter->strvalue, parameter->length); +#endif + + mmi_coder(WAP_CONNECTION_CONFIGURE_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_DOWNLOAD_URL_IND + + $Description: Requests WAP Browser to download a URL + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_DOWNLOAD_URL_IND(T_MMI_WAP_DOWNLOAD_URL_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_DOWNLOAD_URL_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P2( "URL length, Reload: %d, %d", parameter->url_length, parameter->reload); + ATB_trace_string(parameter->Url, parameter->url_length); +#endif + + mmi_coder(WAP_DOWNLOAD_URL_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_BROWSE_CONTROL_IND + + $Description: Sends browsing request to WAP Browser + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_BROWSE_CONTROL_IND(T_MMI_WAP_BROWSE_CONTROL_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_BROWSE_CONTROL_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P1( "Browse command: %d", parameter->browse_command); +#endif + + mmi_coder(WAP_BROWSE_CONTROL_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_KEY_SELECTED_IND + + $Description: Indicate to Browser that a WAP Key has been selected. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_KEY_SELECTED_IND(T_MMI_WAP_KEY_SELECTED_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_KEY_SELECTED_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P1( "keyId: %d", parameter->keyId); +#endif + + mmi_coder(WAP_KEY_SELECTED_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_INPUT_DIALOG_CNF + + $Description: Confirmation of input dialog. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_INPUT_DIALOG_CNF(T_MMI_WAP_INPUT_DIALOG_CNF *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_INPUT_DIALOG_CNF"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P2( "dialog_id, edited: %d, %d", parameter->dialog_id, parameter->edited); + ATB_trace_ushort_string(parameter->Text, parameter->text_length); +#endif + + mmi_coder(WAP_INPUT_DIALOG_CNF_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_PASSWORD_DIALOG_CNF + + $Description: Confirmation of password dialog. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_PASSWORD_DIALOG_CNF(T_MMI_WAP_PASSWORD_DIALOG_CNF *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_PASSWORD_DIALOG_CNF"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P1( "MMI dialog_id: %d", parameter->dialog_id); + ATB_trace_string(parameter->Input, parameter->input_length); + ATB_trace_string(parameter->Password, parameter->password_length); +#endif + + mmi_coder(WAP_PASSWORD_DIALOG_CNF_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_CONFIRM_DIALOG_CNF + + $Description: Confirmation of confirm dialog. + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONFIRM_DIALOG_CNF(T_MMI_WAP_CONFIRM_DIALOG_CNF *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONFIRM_DIALOG_CNF"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P2( "MMI dialog_id: %d, Answer: %d", parameter->dialog_id, parameter->answer); +#endif + + mmi_coder(WAP_CONFIRM_DIALOG_CNF_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_INFO_DIALOG_CNF + + $Description: Confirmation of info dialog. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_INFO_DIALOG_CNF(T_MMI_WAP_INFO_DIALOG_CNF *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_INFO_DIALOG_CNF"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P1( "MMI dialog_id: %d", parameter->dialog_id); +#endif + + mmi_coder(WAP_INFO_DIALOG_CNF_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_DRAW_CARD_REQ + + $Description: Request WAP Browser to draw the current card. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_DRAW_CARD_REQ(T_MMI_WAP_DRAW_CARD_REQ *parameter) +{ + T_WAP_VIEW *View = ATB_wap_get_view(parameter->object_id); + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_DRAW_CARD_REQ"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + if (View) + mmi_coder(WAP_DRAW_CARD_REQ_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_CONNECT_CNF + + $Description: Confirmation to WAP Browser that WAP call is connected + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONNECT_CNF(T_MMI_WAP_CONNECT_CNF *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONNECT_CNF"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + mmi_coder(WAP_CONNECT_CNF_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_DISCONNECT_IND + + $Description: Tell WAP Browser to disconnect + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_DISCONNECT_IND(T_MMI_WAP_DISCONNECT_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_DISCONNECT_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + mmi_coder(WAP_DISCONNECT_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_CACHE_PREPARE_IND + + $Description: Tell WAP Browser to prepare the cache for shutdown + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CACHE_PREPARE_IND(T_MMI_WAP_CACHE_PREPARE_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CACHE_PREPARE_IND"); +#endif + + mmi_coder(WAP_CACHE_PREPARE_IND_ID,(void*)parameter); + + return; +} + + +#ifdef FF_GPF_TCPIP +/******************************************************************************* + + $Function: M_MMI_WAP_CONFIG_CNF + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONFIG_CNF(T_MMI_WAP_CONFIG_CNF *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONFIG_CNF"); +#endif + + mmi_coder(WAP_CONFIG_CNF_ID,(void*)parameter); + + return; +} + +/******************************************************************************* + + $Function: M_MMI_WAP_CONTENT_REQ + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONTENT_REQ(T_MMI_WAP_CONTENT_REQ *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_GET_CONTENT_REQ"); +#endif + + mmi_coder(WAP_CONTENT_REQ_ID,(void*)parameter); + + return; +} + +/******************************************************************************* + + $Function: M_MMI_WAP_CONTENT_POST_REQ + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONTENT_POST_REQ(T_MMI_WAP_CONTENT_POST_REQ *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONTENT_POST_REQ"); +#endif + + mmi_coder(WAP_CONTENT_POST_REQ_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_CONTENT_POST_MORE_IND + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONTENT_POST_MORE_REQ(T_MMI_WAP_CONTENT_POST_MORE_REQ *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONTENT_POST_MORE_REQ"); +#endif + + mmi_coder(WAP_CONTENT_POST_MORE_REQ_ID,(void*)parameter); + + return; +} + +/******************************************************************************* + + $Function: M_MMI_WAP_CONTENT_CNF + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONTENT_CNF(T_MMI_WAP_CONTENT_CNF *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONTENT_CNF"); +#endif + + mmi_coder(WAP_CONTENT_CNF_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_CONTENT_CANCEL_IND + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_CONTENT_CANCEL_IND(T_MMI_WAP_CONTENT_CANCEL_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_CONTENT_CANCEL_IND"); +#endif + + mmi_coder(WAP_CONTENT_CANCEL_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_LOAD_SI_IND + + $Description: Load the service pointed to by a SI + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_LOAD_SI_IND(T_MMI_WAP_PUSH_LOAD_SI_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_PUSH_LOAD_SI_IND"); +#endif + + mmi_coder(WAP_PUSH_LOAD_SI_IND_ID,(void*)parameter); + + return; +} + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_DELETE_SI_IND + + $Description: Delete an SI + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_DELETE_SI_IND(T_MMI_WAP_PUSH_DELETE_SI_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_PUSH_DELETE_SI_IND"); +#endif + + mmi_coder(WAP_PUSH_DELETE_SI_IND_ID,(void*)parameter); + + return; + +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_GET_SI_INFO_REQ + + $Description: Request info on an SI + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_GET_SI_INFO_REQ(T_MMI_WAP_PUSH_GET_SI_INFO_REQ *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_MMI_WAP_PUSH_GET_SI_INFO_REQ"); +#endif + + mmi_coder(WAP_PUSH_GET_SI_INFO_REQ_ID,(void*)parameter); + + return; + +} + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_LOAD_SL_IND + + $Description: Load the service pointed to by an SL + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_LOAD_SL_IND(T_MMI_WAP_PUSH_LOAD_SL_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_LOAD_SL_IND"); +#endif + + mmi_coder(WAP_PUSH_LOAD_SL_IND_ID,(void*)parameter); + + return; +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_DELETE_SL_IND + + $Description: Delete an SL + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_DELETE_SL_IND(T_MMI_WAP_PUSH_DELETE_SL_IND *parameter) +{ +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_DELETE_SL_IND"); +#endif + + mmi_coder(WAP_PUSH_DELETE_SL_IND_ID,(void*)parameter); + + return; + +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_GET_SL_INFO_REQ + + $Description: Request info on an SL + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_GET_SL_INFO_REQ(T_MMI_WAP_PUSH_GET_SL_INFO_REQ *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_GET_SL_INFO_REQ"); +#endif + + mmi_coder(WAP_PUSH_GET_SL_INFO_REQ_ID,(void*)parameter); + + return; + +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_CONNECTION_CNF + + $Description: Confirm that Push connection information has been set up + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_CONNECTION_CNF(T_MMI_WAP_PUSH_CONNECTION_CNF *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_CONNECTION_CNF"); +#endif + + mmi_coder(WAP_PUSH_CONNECTION_CNF_ID,(void*)parameter); + + return; + +} + + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_CHANGE_STATUS_IND + + $Description: Change the status of a push message + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_CHANGE_STATUS_IND(T_MMI_WAP_PUSH_CHANGE_STATUS_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_CHANGE_STATUS_IND"); +#endif + + mmi_coder(WAP_PUSH_CHANGE_STATUS_IND_ID,(void*)parameter); + + return; + +} + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_REMOVE_MESSAGE_IND + + $Description: Remove a push message + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_REMOVE_MESSAGE_IND(T_MMI_WAP_PUSH_REMOVE_MESSAGE_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_REMOVE_MESSAGE_IND"); +#endif + + mmi_coder(WAP_PUSH_REMOVE_MESSAGE_IND_ID,(void*)parameter); + + return; + +} + +/******************************************************************************* + + $Function: MMI_WAP_PUSH_CHECK_UNLOADED_MSG_REQ + + $Description: Check if there are any unloaded messages + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_CHECK_UNLOADED_MSG_REQ(T_MMI_WAP_PUSH_CHECK_UNLOADED_MSG_REQ *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_CHECK_UNLOADED_MSG_REQ"); +#endif + + mmi_coder(WAP_PUSH_CHECK_UNLOADED_MSG_REQ_ID,(void*)parameter); + + return; + +} + + +/******************************************************************************* + + + $Function: M_MMI_WAP_PUSH_SAVE_TO_FLASH_IND + + $Description: Save push repository to flash + SPR#2086 - Added + + $Returns: None. + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_SAVE_TO_FLASH_IND(T_MMI_WAP_PUSH_SAVE_TO_FLASH_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_SAVE_TO_FLASH_IND"); +#endif + + mmi_coder(WAP_PUSH_SAVE_TO_FLASH_IND_ID,(void*)parameter); + + return; + +} + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_SMS_RECEIVED_IND + + $Description: WAP SMS has been received + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_SMS_RECEIVED_IND(T_MMI_WAP_PUSH_SMS_RECEIVED_IND *parameter) +{ +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_SMS_RECEIVED_IND"); +#endif + + mmi_coder(WAP_PUSH_SMS_RECEIVED_IND_ID, (void*)parameter); + + return; +} + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_SMS_SENT_IND + + $Description: WAP SMS has been sent + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_SMS_SENT_IND(T_MMI_WAP_PUSH_SMS_SENT_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_SMS_SENT_IND"); +#endif + + mmi_coder(WAP_PUSH_SMS_SENT_IND_ID, (void *)parameter); + + return; +} + +/******************************************************************************* + + $Function: M_MMI_WAP_PUSH_SMS_ERROR_IND + + $Description: WAP SMS has not been sent + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_MMI_WAP_PUSH_SMS_ERROR_IND(T_MMI_WAP_PUSH_SMS_ERROR_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_PUSH_SMS_ERROR_IND"); +#endif + + mmi_coder(WAP_PUSH_SMS_ERROR_IND_ID, (void *)parameter); + + return; +} + +#endif + + +#ifdef FF_GPF_TCPIP +/******************************************************************************* + + + $Function: M_WAP_MMI_CONTROL_IND + + $Description: + + $Returns: + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_CONTROL_IND(T_WAP_MMI_CONTROL_IND *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_CONTROL_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P3( "Status, Error, Click: %d, %d, %d", parameter->status_code, parameter->error_code, + parameter->play_standard_click); +#endif + + View = ATB_wap_get_view(parameter->object_id); + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + /* Intercept fatal error */ + //if (parameter->error_code==8002) + //OUT OF MEMORY code 0x903 + if (parameter->error_code==2307) + { + AUI_error_dialog(View, parameter->error_code); + return; + } + + /* SPR#2086 - SH - Modified slightly to report status values + * correctly when downloading content using SAR */ + + /* If WSP session failed, try using second IP address */ + + if (parameter->error_code==1014 && !View->secondaryIP) + { + ATB_wap_secondary_IP(View); + return; + } + + /* For any other error, display the error dialog */ + + if (parameter->error_code!=0 && parameter->error_code != 0x20) + { + AUI_error_dialog(View, parameter->error_code); + return; + } + + /* Otherwise, report selected status values */ + + switch(parameter->status_code) + { + case 12: /* Data is being downloaded */ + ATB_wap_status_change(View, ATB_WAP_DOWNLOADING); + break; + + case 13: /* Data is no longer being downloaded */ + ATB_wap_status_change(View, ATB_WAP_NO_STATUS); + break; + + case 7: /* Content taken from network server */ + if (View->object_id==WAP_DOWNLOAD_VIEW) + { + ATB_wap_status_change(View, ATB_WAP_DOWNLOADING); + } + break; + + case 9: /* Content no longer being taken */ + if (View->object_id==WAP_DOWNLOAD_VIEW) + { + ATB_wap_status_change(View, ATB_WAP_NO_STATUS); + } + break; + } + + return; +} + +#else /* #ifdef FF_GPF_TCPIP */ + +/******************************************************************************* + + $Function: M_WAP_MMI_CONTROL_IND + + $Description: Send control information to MMI + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_CONTROL_IND(T_WAP_MMI_CONTROL_IND *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_CONTROL_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P3( "Status, Error, Click: %d, %d, %d", parameter->status_code, parameter->error_code, + parameter->play_standard_click); +#endif + + View = ATB_wap_get_view(parameter->object_id); + + /* Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + /* Intercept fatal error */ + + if (parameter->error_code==8002) + + { + AUI_error_dialog(View, parameter->error_code); + return; + } + + /* For non-fatal error, do not report if there is no view open */ + + if (!View) + { + TRACE_EVENT("View is NULL"); + return; + } + + /* Data is being downloaded; update status display */ + + if (parameter->status_code==14) + { + ATB_wap_status_change(View, ATB_WAP_DOWNLOADING); + } + + /* Data is no longer being downloaded */ + + if (parameter->status_code==15) + { + ATB_wap_status_change(View, ATB_WAP_NO_STATUS); + } + + /* If WSP session failed, try using second IP address */ + + if (parameter->error_code==1014 && !View->secondaryIP) + { + ATB_wap_secondary_IP(View); + return; + } + + /* Create error dialog if required */ + + if (parameter->error_code!=0 && parameter->error_code != 0x20) + { + AUI_error_dialog(View, parameter->error_code); + + } + + return; +} + + +#endif /* ! #ifdef FF_GPF_TCPIP */ + +/******************************************************************************* + + + $Function: M_WAP_MMI_NEW_KEY_IND + + $Description: A new WAP key is to be created. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_NEW_KEY_IND(T_WAP_MMI_NEW_KEY_IND *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_NEW_KEY_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P2( "Key ID, Key Type: %d, %d", parameter->keyId, parameter->key_type); + ATB_trace_ushort_string(parameter->Label, parameter->label_length); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + if (parameter->key_type == WAP_KEY_PREV) + AUI_wap_change_soft_key(View, parameter->Label, + (USHORT)parameter->label_length, parameter->keyId); + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_INPUT_DIALOG_REQ + + $Description: An input dialog is to be displayed. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_INPUT_DIALOG_REQ(T_WAP_MMI_INPUT_DIALOG_REQ *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_INPUT_DIALOG_REQ"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P2( "MMI dialog_id, is_password: %d, %d", parameter->dialog_id, parameter->is_password); + TRACE_EVENT_P3( "MMI empty_ok, visible, size: %d, %d, %d", parameter->empty_ok, +parameter->visible, parameter->size); + ATB_trace_ushort_string(parameter->Title, parameter->title_length); + ATB_trace_ushort_string(parameter->Input, parameter->input_length); + ATB_trace_ushort_string(parameter->Format, parameter->format_length); +#endif // TRACE_ATBWAPACI + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + +#ifdef FF_GPF_TCPIP + AUI_wap_input_dialog_open(parameter, View); +#else + AUI_wap_input_dialog_open(parameter); +#endif + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_PASSWORD_DIALOG_REQ + + $Description: A password dialog is to be displayed. + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_PASSWORD_DIALOG_REQ(T_WAP_MMI_PASSWORD_DIALOG_REQ *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_PASSWORD_DIALOG_REQ"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P2( "MMI dialog_id, dialog_type: %d, %d", parameter->dialog_id, parameter->dialog_type); + /* SPR#2393 - SH - Changed password fields */ + ATB_trace_string(parameter->Realm, parameter->realm_length); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + +#ifdef FF_GPF_TCPIP + AUI_wap_password_dialog_open(parameter, View); +#else + AUI_wap_password_dialog_open(parameter); +#endif + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_CONFIRM_DIALOG_REQ + + $Description: A confirmation dialog is to be displayed. + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_CONFIRM_DIALOG_REQ(T_WAP_MMI_CONFIRM_DIALOG_REQ *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_CONFIRM_DIALOG_REQ"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P1( "MMI dialog_id: %d", parameter->dialog_id); + ATB_trace_ushort_string(parameter->Message, parameter->message_length); + ATB_trace_ushort_string(parameter->Ok_key, parameter->ok_key_length); + ATB_trace_ushort_string(parameter->Cancel_key, parameter->cancel_key_length); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + +#ifdef FF_GPF_TCPIP + AUI_wap_confirm_dialog_open(parameter, View); +#else + AUI_wap_confirm_dialog_open(parameter); +#endif + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_INFO_DIALOG_REQ + + $Description: An info/alert dialog is to be displayed. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_INFO_DIALOG_REQ(T_WAP_MMI_INFO_DIALOG_REQ *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_INFO_DIALOG_REQ"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); + TRACE_EVENT_P1( "MMI dialog_id: %d", parameter->dialog_id); + ATB_trace_ushort_string(parameter->Message, parameter->message_length); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + +#ifdef FF_GPF_TCPIP + AUI_wap_info_dialog_open(parameter, View); +#else + AUI_wap_info_dialog_open(parameter); +#endif + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_NEW_CARD_IND + + $Description: A new card is to be created. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_NEW_CARD_IND(T_WAP_MMI_NEW_CARD_IND *parameter) +{ + T_WAP_VIEW *View; +#ifdef CO_UDP_IP + UBYTE *History = (UBYTE *)parameter->History; + U32 historyPointer = History[4] + History[5]*0x100 + History[6]*0x10000 + History[7]*0x1000000; + /* Look at second history entry (bytes 4 to 7) - this is the previous card. + * If this is zero, then there shouldn't be a "back" key */ + USHORT historyIndex; +#endif + + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_NEW_CARD_IND"); + TRACE_EVENT_P1("object ID: %d",parameter->object_id); + TRACE_EVENT_P1( "is_bookmarkable: %d", parameter->is_bookmarkable); + ATB_trace_ushort_string(parameter->Title, parameter->title_length); + ATB_trace_string(parameter->Url, parameter->url_length); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + { + return; + } + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + /* SPR#1816 - SH - Store title, or "Untitled" if title is blank */ + + if (parameter->title_length > 0) + { + /* Copy a max of CARD_TITLE_MAX_LEN unicode characters */ + parameter->title_length = ATB_uc_text_copy(View->Title, parameter->Title, CARD_TITLE_MAX_LEN); + /* Convert to MMI unicode, store in View->Title */ + ATB_uc_text_convert(View->Title, parameter->title_length); + } + else + { + /* Use "Untitled" text tag */ + parameter->title_length = AUI_wap_stringID(View->Title, CARD_TITLE_MAX_LEN, WAP_STRING_UNTITLED); + } + + /* SPR#1816 - SH - Copy URL, making sure it's not too long */ + + strncpy(View->URL, parameter->Url, URL_MAX_LEN); + + /* Add card name & URL to top of history list + * SPR#1816 - SH - Do this before cropping title */ + +#ifdef FF_GPF_TCPIP + if (ATB_wap_profile_setting(WAP_STATUS_SAVEHISTORY)) + { +// xreddymn Dec-10-2004 MMI-SPR-26159 - Insert title only if insert URL was successful +#if(0) // If set to 1, allows duplicate URLs to be inserted into history list + ATB_wap_entry_insert(WAP_HISTORY_LIST, View->History, (char *)View->Title, 0); // Add as entry 0 (last entry lost) + ATB_wap_entry_insert(WAP_URL_LIST, View->HistoryURL, View->URL, 0); +#else // Insert title only if insert URL was successful + if(ATB_wap_entry_insert(WAP_URL_LIST, View->HistoryURL, View->URL, 0)!=WAP_FAIL) + ATB_wap_entry_insert(WAP_HISTORY_LIST, View->History, (char *)View->Title, 0); // Add as entry 0 (last entry lost) +#endif + } +//changes +#else + if (View->Status & WAP_STATUS_SAVEHISTORY) + { + ATB_wap_entry_insert(View->History, (char *)View->Title, 0); /* Add as entry 0 (last entry lost) */ + ATB_wap_entry_insert(View->HistoryURL, View->URL, 0); + + } +#endif +//changes + /* Crop title so it fits on screen */ + + ATB_uc_text_crop(View->Title, parameter->title_length, WAP_SCREEN_WIDTH-WAP_CHAR_WIDTH); + + /* Check to see if user can go back from this card */ + +#ifdef CO_UDP_IP + if (historyPointer != 0) + { + View->CanGoBack = TRUE; + } + else + { + View->CanGoBack = FALSE; + } +#else + View->CanGoBack = TRUE; +#endif + + View->CustSoftKeys = FALSE; /* Use default softkeys */ + + /* SPR#1575 - SH - New card is being read in */ + + ATB_wap_status_change(View, ATB_WAP_CARD_READING); + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_DRAW_CARD_IND + + $Description: Tell MMI to draw the card. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_DRAW_CARD_IND(T_WAP_MMI_DRAW_CARD_IND *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_DRAW_CARD_IND"); + TRACE_EVENT_P1("object ID: %d",parameter->object_id); + TRACE_EVENT_P2("contentWidth: %d, contentHeight: %d",parameter->contentWidth, parameter->contentHeight); + TRACE_EVENT_P2("contentPosX: %d, contentPosY: %d",parameter->contentPosX, parameter->contentPosY); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + View->cardWidth = parameter->contentWidth; + View->cardHeight = parameter->contentHeight; + View->cardXPosition = parameter->contentPosX; + View->cardYPosition = parameter->contentPosY; + + View->acceptUpdate = FALSE; + /* Set to FALSE as default, to ignore any attempts to redraw parts of the card + * rather than the whole card (e.g. when selecting an option). Only allows a card + * to be updated if M_WAP_MMI_CLEAR_CARD_IND is called. */ + + return; +} + + +/******************************************************************************* + + $Function: M_WAP_MMI_CLEAR_CARD_IND + + $Description: Clear the card display. Allows card to be updated. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_CLEAR_CARD_IND(T_WAP_MMI_CLEAR_CARD_IND *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_CLEAR_CARD_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + View->acceptUpdate = TRUE; + + /* Clearing the card means we're going to update the whole thing, so this update + * is permitted (see M_WAP_MMI_DRAW_CARD_IND). */ + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_SEND_TEXT_IND + + + $Description: A text is to be displayed. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_SEND_TEXT_IND(T_WAP_MMI_SEND_TEXT_IND *parameter) +{ + T_WAP_VIEW *View; + T_WAP_ELEMENT *Element; + T_WAP_MMI_SEND_TEXT_IND *copy; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_SEND_TEXT_IND"); + ATB_trace_ushort_string(parameter->Text, parameter->text_length); + ATB_trace_ushort_string(parameter->Formatstring, parameter->formatstring_length); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + { +#ifdef FF_GPF_TCPIP + // xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + // Need to free if the memory was allocated by us in wapadapter. + if(TRUE == parameter->free_flag) + { + T_MMI_WAP_MEM_FREE_IND free_mem_ind; + free_mem_ind.data = (UBYTE*)parameter->Text; + free_mem_ind.imageObject=FALSE; + M_MMI_WAP_FREE_MEM_IND(&free_mem_ind); + } +#endif + return; + } + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); +#ifdef FF_GPF_TCPIP + // xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + // Need to free if the memory was allocated by us in wapadapter. + if(TRUE == parameter->free_flag) + { + T_MMI_WAP_MEM_FREE_IND free_mem_ind; + free_mem_ind.data = (UBYTE*)parameter->Text; + free_mem_ind.imageObject=FALSE; + M_MMI_WAP_FREE_MEM_IND(&free_mem_ind); + } +#endif + return; + } + + /* If an update is forbidden, ignore this event */ + + if (!View->acceptUpdate) + { +#ifdef FF_GPF_TCPIP + // xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + // Need to free if the memory was allocated by us in wapadapter. + if(TRUE == parameter->free_flag) + { + T_MMI_WAP_MEM_FREE_IND free_mem_ind; + free_mem_ind.data = (UBYTE*)parameter->Text; + free_mem_ind.imageObject=FALSE; + M_MMI_WAP_FREE_MEM_IND(&free_mem_ind); + } +#endif + return; + } + + /* Allocate memory and copy the data */ + + Element = ATB_wap_buffer_add_element(View, WAP_TEXT); /* SPR#1921 - SH */ + + copy = (T_WAP_MMI_SEND_TEXT_IND *)AUI_wap_memory_alloc(sizeof(T_WAP_MMI_SEND_TEXT_IND)); + memcpy((void *)copy, (void *)parameter, sizeof(T_WAP_MMI_SEND_TEXT_IND)); + //xrashmic 12 May, 2005 MMI-SPR-30834 + //For input text box, adding of [] is moved from wap adapter to bmi + if(WAP_TEXT_INPUT == parameter->type) + { + if(parameter->text_length==0) + { + copy->text_length=2; + copy->Text = (USHORT *)AUI_wap_memory_alloc((copy->text_length+1)*sizeof(USHORT)); + } + else + { + copy->text_length=parameter->text_length+2; + copy->Text = (USHORT *)AUI_wap_memory_alloc((copy->text_length+1)*sizeof(USHORT)); + memcpy((void *)(copy->Text+1), (void *)parameter->Text, parameter->text_length*sizeof(USHORT)); + } + copy->Text[0] = (USHORT) '['; + copy->Text[copy->text_length-1] = (USHORT) ']'; + copy->Text[copy->text_length] = (USHORT) '\0'; + } + else + { + if (parameter->text_length != 0) + { + copy->Text = (USHORT *)AUI_wap_memory_alloc(parameter->text_length*sizeof(USHORT)); + memcpy((void *)copy->Text, (void *)parameter->Text, parameter->text_length*sizeof(USHORT)); + } + } + if (parameter->formatstring_length != 0) + { + copy->Formatstring = (USHORT *)AUI_wap_memory_alloc(parameter->formatstring_length*sizeof(USHORT)); + memcpy((void *)copy->Formatstring, (void *)parameter->Text, parameter->formatstring_length*sizeof(USHORT)); + } + + Element->data = (void *)copy; + +#ifdef FF_GPF_TCPIP + // xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + // Need to free if the memory was allocated by us in wapadapter. + if(TRUE == parameter->free_flag) + { + T_MMI_WAP_MEM_FREE_IND free_mem_ind; + free_mem_ind.data = (UBYTE*)parameter->Text; + free_mem_ind.imageObject=FALSE; + M_MMI_WAP_FREE_MEM_IND(&free_mem_ind); + } +#endif + return; +} + +#ifdef FF_GPF_TCPIP +/******************************************************************************* + + + $Function: M_WAP_MMI_RADIO_BUTTON_IND + + + $Description: A radio button is to be displayed. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_RADIO_BUTTON_IND(T_WAP_MMI_RADIO_BUTTON_IND *parameter) +{ + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_RADIO_BUTTON_IND"); + TRACE_EVENT_P2("MMI object ID: %d, element ID: %d",parameter->object_id, parameter->element_id); + TRACE_EVENT_P2("MMI active, selected: %d, %d", parameter->active, parameter->selected); + TRACE_EVENT_P2("MMI pX, pY: %d, %d", parameter->pX, parameter->pY); + TRACE_EVENT_P2("MMI pWidth, pHeight: %d, %d", parameter->pWidth, parameter->pHeight); +#endif + + return; +} + +/******************************************************************************* + + + $Function: M_WAP_MMI_DRAW_BORDER_IND + + $Description: A border element is to be displayed. + //kyle 29 Jun, 2005 MMI-SPR-32462 + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_DRAW_BORDER_IND(T_WAP_MMI_DRAW_BORDER_IND *parameter) +{ + + T_WAP_VIEW *View; + T_WAP_ELEMENT *Element; + T_WAP_MMI_DRAW_BORDER_IND *copy; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_DRAW_BORDER_IND"); + TRACE_EVENT_P1("WAP object ID: %d",parameter->object_id); + TRACE_EVENT_P4("Bottom border pX, pY, pWidth, pHeight: %d, %d, %d, %d", parameter->borderBottom.pX, parameter->borderBottom.pY, parameter->borderBottom.pWidth, parameter->borderBottom.pHeight); + TRACE_EVENT_P4("Left border pX, pY, pWidth, pHeight: %d, %d, %d, %d", parameter->borderLeft.pX, parameter->borderLeft.pY, parameter->borderLeft.pWidth, parameter->borderLeft.pHeight); + TRACE_EVENT_P4("Right border pX, pY, pWidth, pHeight: %d, %d, %d, %d", parameter->borderRight.pX, parameter->borderRight.pY, parameter->borderRight.pWidth, parameter->borderRight.pHeight); + TRACE_EVENT_P4("Top border pX, pY, pWidth, pHeight: %d, %d, %d, %d", parameter->borderTop.pX, parameter->borderTop.pY, parameter->borderTop.pWidth, parameter->borderTop.pHeight); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + /* If an update is forbidden, ignore this event */ + + if (!View->acceptUpdate) + return; + + /* Allocate memory and copy the data */ + + Element = ATB_wap_buffer_add_element(View, WAP_BORDER); /* SPR#1921 - SH */ + + copy = (T_WAP_MMI_DRAW_BORDER_IND *)AUI_wap_memory_alloc(sizeof(T_WAP_MMI_DRAW_BORDER_IND)); + memcpy((void *)copy, (void *)parameter, sizeof(T_WAP_MMI_DRAW_BORDER_IND)); + + Element->data = (void *)copy; + + return; +} + +#endif + +/******************************************************************************* + + $Function: M_WAP_MMI_SEND_IMAGE_IND + + $Description: An image is to be displayed. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_SEND_IMAGE_IND(T_WAP_MMI_SEND_IMAGE_IND *parameter) +{ + T_WAP_VIEW *View; + T_WAP_ELEMENT *Element; + T_WAP_MMI_SEND_IMAGE_IND *copy; +#ifdef FF_GPF_TCPIP + T_MMI_WAP_MEM_FREE_IND free_mem_ind; //xrashmic 30 Aug, 2005 MMI-SPR-34024(OMAPS00048918) mem leak fix +#endif + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_SEND_IMAGE_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + { +#ifdef FF_GPF_TCPIP + // xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + // Need to free if the memory was allocated for plugin image in wapadapter. + if(parameter->pluginImage) + { + free_mem_ind.data = parameter->ImageReq; + free_mem_ind.imageObject=TRUE; + M_MMI_WAP_FREE_MEM_IND(&free_mem_ind); + } +#endif + return; + } + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); +#ifdef FF_GPF_TCPIP + // xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + // Need to free if the memory was allocated for plugin image in wapadapter. + if(parameter->pluginImage) + { + free_mem_ind.data = parameter->ImageReq; + free_mem_ind.imageObject=TRUE; + M_MMI_WAP_FREE_MEM_IND(&free_mem_ind); + } +#endif + return; + } + + /* If an update is forbidden, ignore this event */ + + if (!View->acceptUpdate) + { +#ifdef FF_GPF_TCPIP + // xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + // Need to free if the memory was allocated for plugin image in wapadapter. + if(parameter->pluginImage) + { + free_mem_ind.data = parameter->ImageReq; + free_mem_ind.imageObject=TRUE; + M_MMI_WAP_FREE_MEM_IND(&free_mem_ind); + } +#endif + return; + } +#ifdef FF_GPF_TCPIP + //xrashmic 21 Jan, 2005 MMI-SPR-28223 + //Saving the information passed by wap adapter if the image is from plugin or normal wap page. + if(parameter->pluginImage) + Element = ATB_wap_buffer_add_element(View, WAP_PLUGIN_IMAGE); /* SPR#1921 - SH */ + else +#endif + Element = ATB_wap_buffer_add_element(View, WAP_IMAGE); /* SPR#1921 - SH */ + copy = (T_WAP_MMI_SEND_IMAGE_IND *)AUI_wap_memory_alloc(sizeof(T_WAP_MMI_SEND_IMAGE_IND)); + if (copy) + { + memcpy((void *)copy, (void *)parameter, sizeof(T_WAP_MMI_SEND_IMAGE_IND)); + + +#ifdef FF_GPF_TCPIP + //xrashmic 30 Aug, 2005 MMI-SPR-34024(OMAPS00048918) mem leak fix + // Only for plugin images make a copy at bmi. + if(parameter->pluginImage) + { + if (parameter->image_length != 0) + { + copy->Image = (UBYTE *)AUI_wap_memory_alloc(parameter->image_length*sizeof(UBYTE)); + memcpy((void *)copy->Image, (void *)parameter->Image, parameter->image_length*sizeof(UBYTE)); + } + } + else + copy->Image = (UBYTE*)parameter->Image; +#else + if (parameter->image_length != 0) + { + copy->Image = (UBYTE *)AUI_wap_memory_alloc(parameter->image_length*sizeof(UBYTE)); + memcpy((void *)copy->Image, (void *)parameter->Image, parameter->image_length*sizeof(UBYTE)); + } +#endif + } + + Element->data = (void *)copy; + +#ifdef FF_GPF_TCPIP + //xrashmic 30 Aug, 2005 MMI-SPR-34024(OMAPS00048918) mem leak fix + //freeing ImageReq data in WAP memory only for plugin images. + if(parameter->pluginImage) + { + // xreddymn MMI-SPR-30834 May-14-2005: free ImageReq data in WAP memory + free_mem_ind.data = parameter->ImageReq; + // xrashmic 20 Dec, 2005 OMAPS00061232 (on behalf of xreddymn) + // Add this to differentiate between image objects and text objects to be freed in wap adapter + free_mem_ind.imageObject=TRUE; + M_MMI_WAP_FREE_MEM_IND(&free_mem_ind); + } +#endif + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_SEND_TABLE_IND + + $Description: A table/fieldset is to be displayed. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_SEND_TABLE_IND(T_WAP_MMI_SEND_TABLE_IND *parameter) +{ + T_WAP_VIEW *View; + T_WAP_ELEMENT *Element; + T_WAP_MMI_SEND_TABLE_IND *copy; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_SEND_TABLE_IND"); + TRACE_EVENT_P1("object ID: %d",parameter->object_id); + TRACE_EVENT_P2("Columns: %d, Rows: %d",parameter->cols_length, parameter->rows_length); + TRACE_EVENT_P4("pX: %d, pY: %d, pWidth: %d, pHeight: %d",parameter->pX, parameter->pY, parameter->pWidth, parameter->pHeight); + ATB_trace_ushort_string(parameter->Title, parameter->title_length); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + /* If an update is forbidden, ignore this event */ + + if (!View->acceptUpdate) + return; + + /* Allocate memory and copy the data */ + + Element = ATB_wap_buffer_add_element(View, WAP_TABLE); /* SPR#1921 - SH */ + + copy = (T_WAP_MMI_SEND_TABLE_IND *)AUI_wap_memory_alloc(sizeof(T_WAP_MMI_SEND_TABLE_IND)); + memcpy((void *)copy, (void *)parameter, sizeof(T_WAP_MMI_SEND_TABLE_IND)); + + if (parameter->title_length != 0) + { + copy->Title = (USHORT *)AUI_wap_memory_alloc(parameter->title_length*sizeof(USHORT)); + memcpy((void *)copy->Title, (void *)parameter->Title, parameter->title_length*sizeof(USHORT)); + } + if (parameter->cols_length != 0) + { + copy->ColWidth = (SHORT *)AUI_wap_memory_alloc(parameter->cols_length*sizeof(SHORT)); + memcpy((void *)copy->ColWidth, (void *)parameter->ColWidth, parameter->cols_length*sizeof(SHORT)); + } + if (parameter->rows_length != 0) + { + copy->RowHeight = (SHORT *)AUI_wap_memory_alloc(parameter->rows_length*sizeof(SHORT)); + memcpy((void *)copy->RowHeight, (void *)parameter->RowHeight, parameter->rows_length*sizeof(SHORT)); + } + Element->data = (void *)copy; + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_CARD_DRAW_COMPLETED_IND + + $Description: Card drawing is completed, card may be displayed. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_CARD_DRAW_COMPLETED_IND(T_WAP_MMI_CARD_DRAW_COMPLETED_IND *parameter) +{ + T_WAP_VIEW *View; + UBYTE temp; + // July 13 2005 REF: MMI-SPR-32012 x0012849 + // To change the functionality of RSK, when there is no page to go back +#ifdef FF_GPF_TCPIP + if(HISTORY_NOT_AVAILABLE== parameter->object_id) + { + ExitWAP(WAP_NONE); + return; + } + //xrashmic 17 Aug, 2005 MMI-SPR-31364 + //When it is detected that a very large page is being opened, the wap adapter sends this message. + //We need to exit wap and display a error dialog as we have memory constraints. + else if(OUT_OF_MEM_LARGE_PAGE == parameter->object_id ) + { + ExitWAP(WAP_OUT_OF_MEM); + return; + } + +#endif + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + temp = dspl_Enable(0); + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_CARD_DRAW_COMPLETED_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + /* If an update is forbidden, ignore this event */ + + if (!View->acceptUpdate) + { + dspl_Enable(temp); + return; + } + + /* Destroy the current card, and make the new buffered card the current card */ + + ATB_wap_buffer_clear(View); + View->ElementHeader = View->NewElementHeader; + View->NewElementHeader = NULL; + + AUI_wap_card_show_req(View); + dspl_Enable(temp); + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_CONNECT_REQ + + $Description: The connection (GSM or GPRS) can now be made. + The GSM connection occurs in this function. + The GPRS attachment is made in this function. Once GPRS is + attached, the connection proceeds in function connect_gprs() below. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ +#ifdef FF_GPF_TCPIP + +extern void M4_DebugStringMessage(char *in_string, UINT8 ucNumber,unsigned long para); +// xreddymn Mar-05-2005 MMI-SPR-26144: This function is called to check if +// a MMS send operation was cancelled by the user +extern UBYTE AUI_mms_cancel_status(void); + +void M_WAP_MMI_CONNECT_REQ(T_WAP_MMI_CONNECT_REQ *parameter) +{ + T_WAP_VIEW *View; + char temp[NUMBER_MAX_LEN+1]; + T_ACI_BS_SPEED speed; + + + T_SOCK_BEARER_INFO bearer_data; + T_SOCKET_NODE *bearer_node = NULL; + T_SOCK_RESULT result; + + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_CONNECT_REQ"); + TRACE_EVENT_P2("MMI object ID: %d, bearer status: %d", parameter->object_id, parameter->bearer_status); +#endif + + // xreddymn Feb-23-2005 MMI-SPR-26144: If the user has pressed Cancel, do not connect + if(AUI_mms_cancel_status()) return; + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + + + if(parameter->bearer_status == 1) + { + + TRACE_EVENT("SAPI_BEARER_REQUEST"); + + bearer_data.bearer_handle = 0; + bearer_data.app_handle = parameter->wap_app_handle; + + switch (View->Profile->AccessType) + { + case WAP_CS_DATA: + { + bearer_data.bearer_type = SOCK_BEARER_GSM; + bearer_data.phone_nr_valid = TRUE; + bearer_data.cid = 1; + bearer_data.user_id_valid = TRUE; + bearer_data.password_valid = TRUE; + strcpy(bearer_data.phone_nr, View->Profile->DialupNumber); + strcpy(bearer_data.user_id, View->Profile->Username); + strcpy(bearer_data.password, View->Profile->Password); + bearer_data.precedence = 0; + bearer_data.delay = 0; + bearer_data.reliability = 0; + bearer_data.peak_throughput = 0; + bearer_data.mean_througput = 0; + + bearer_data.ip_address = SOCK_IPADDR_ANY; + bearer_data.dns1 = SOCK_IPADDR_ANY; + bearer_data.dns2 = SOCK_IPADDR_ANY; + bearer_data.gateway = SOCK_IPADDR_ANY; + bearer_data.authtype = SOCK_AUTH_NO; + bearer_data.data_compr = FALSE; + bearer_data.header_comp = FALSE; + bearer_data.shareable = FALSE; + + break; + } +#ifdef GPRS + case WAP_GPRS_DATA: + { + bearer_data.bearer_type = SOCK_BEARER_GPRS; + bearer_data.apn_valid = TRUE; + bearer_data.cid = 1; + bearer_data.user_id_valid = TRUE; + bearer_data.password_valid = TRUE; + strcpy(bearer_data.apn, View->Profile->APN); + strcpy(bearer_data.user_id, View->Profile->Username); + strcpy(bearer_data.password, View->Profile->Password); + bearer_data.precedence = 0; + bearer_data.delay = 0; + bearer_data.reliability = 0; + bearer_data.peak_throughput = 0; + bearer_data.mean_througput = 0; + bearer_data.user_id_valid = TRUE; + bearer_data.password_valid = TRUE; + + bearer_data.ip_address = SOCK_IPADDR_ANY; + bearer_data.dns1 = SOCK_IPADDR_ANY; + bearer_data.dns2 = SOCK_IPADDR_ANY; + bearer_data.gateway = SOCK_IPADDR_ANY; + bearer_data.authtype = SOCK_AUTH_NO; + bearer_data.data_compr = FALSE; + bearer_data.header_comp = FALSE; + bearer_data.shareable = FALSE; + + break; + } + } +#endif + + bearer_node = (T_SOCKET_NODE *)parameter->node; + + if(bearer_node == NULL) + { + TRACE_ERROR("Error: M_WAP_MMI_CONNECT_REQ()"); + return; + } + + result = sock_open_bearer((T_SOCK_API_INSTANCE)parameter->instance, SOCK_BEARER_AS_SPECIFIED, 0,&bearer_data, wap_sock_app_callback, bearer_node); + + if(result != SOCK_RESULT_OK) + { + TRACE_ERROR("M_WAP_MMI_CONNECT_REQ(): error in sock_open_bearer()"); + TRACE_EVENT_P1("result: %d", result); + return; + } + else + { + TRACE_EVENT_P1("sock_open_bearer(): socket_api_instance: %d", result); + } + } + else + { + TRACE_ERROR("M_WAP_MMI_CONNECT_REQ(): Unknown bearer status"); + } + + + + return; +} + + +/******************************************************************************* + + $Function: connect + + $Description: Connect + SPR#2086 - Added + + $Returns: None + + $Arguments: object_id - the current session + +*******************************************************************************/ + +void connect(UBYTE object_id) +{ + T_WAP_VIEW *View; + char temp[NUMBER_MAX_LEN+1]; + T_ACI_BS_SPEED speed; + + char TraceBuffer[100]; + + + sprintf(TraceBuffer, "connect called"); + //M4_DebugStringMessage( TraceBuffer,(strlen(TraceBuffer)), 0); + + if (!(View = ATB_wap_get_view(object_id))) + return; + + switch (View->Profile->AccessType) + { + case WAP_CS_DATA: + /* CSD call - connect straight away */ + + sAT_PercentPPP(0,1,View->Profile->Username, View->Profile->Password, USE_NO_PPP_FOR_AAA); + sAT_PercentWAP(0,0); + sAT_PercentWAP(0,1); + + /* Set the connection speed */ + + switch(View->Profile->ConnectionSpeed) + { + case WAP_ANALOGUE: + speed = BS_SPEED_AUTO; + break; + case WAP_ISDN9600: + speed = BS_SPEED_9600_V110; + break; + case WAP_ISDN14400: + speed = BS_SPEED_14400_V110; + break; + default: + speed = BS_SPEED_9600_V34; + break; + } + //Nov 02, 2005 DR OMAPS00052132 xdeepadh + //The usage of ATI enum is put under the flag FF_ATI +#ifdef FF_ATI + sAT_PlusCBST(CMD_SRC_ATI_1, speed, CBST_NAM_Asynch, CBST_CE_NonTransparent); + /* Make the call */ + sprintf(temp, "=%s", View->Profile->DialupNumber); + atD(temp,CMD_SRC_ATI_1); +#endif //FF_ATI + break; + +#ifdef GPRS + case WAP_GPRS_DATA: + { + /* GPRS call - attach now. If attached, connect. + * If not, wait until attach succeeds */ + + T_CGATT_STATE regstate; + + /* Check to see if attached */ + + qAT_PlusCGATT ( CMD_SRC_LCL, ®state ); +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("Reg state: %d", regstate); +#endif + + /* If we're not attached, attempt to do so */ + + if (regstate!=CGATT_STATE_ATTACHED) + { + /* Display status "attaching" */ + ATB_wap_status_change(View, ATB_WAP_ATTACHING); + /* Attempt to attach */ + sAT_PlusCGATT ( CMD_SRC_LCL, CGATT_STATE_ATTACHED ); + } + /* Otherwise, go straight to GPRS connection */ + else + { + connect_gprs(object_id); + } + } + break; +#endif + + default: + TRACE_EVENT("ERROR: Illegal access type!"); + AUI_error_dialog(View, ERROR_CALL_DISCONNECTED); + break; + } +} + +#else /* #ifdef FF_GPF_TCPIP */ + +void M_WAP_MMI_CONNECT_REQ(T_WAP_MMI_CONNECT_REQ *parameter) +{ + T_WAP_VIEW *View; + char temp[NUMBER_MAX_LEN+1]; + T_ACI_BS_SPEED speed; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_CONNECT_REQ"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + + switch (View->Profile->AccessType) + { + case WAP_CS_DATA: + /* CSD call - connect straight away */ + + sAT_PercentPPP(0,1,View->Profile->Username, View->Profile->Password, USE_NO_PPP_FOR_AAA); + sAT_PercentWAP(0,0); + sAT_PercentWAP(0,1); + + /* Set the connection speed */ + + switch(View->Profile->ConnectionSpeed) + { + case WAP_ANALOGUE: + speed = BS_SPEED_AUTO; + break; + case WAP_ISDN9600: + speed = BS_SPEED_9600_V110; + break; + case WAP_ISDN14400: + speed = BS_SPEED_14400_V110; + break; + default: + speed = BS_SPEED_9600_V34; + break; + } + //Nov 02, 2005 DR OMAPS00052132 xdeepadh + //The usage of ATI enum is put under the flag FF_ATI +#ifdef FF_ATI + sAT_PlusCBST(CMD_SRC_ATI_1, speed, CBST_NAM_Asynch, CBST_CE_NonTransparent); + /* Make the call */ + sprintf(temp, "=%s", View->Profile->DialupNumber); + atD(temp,CMD_SRC_ATI_1); +#endif //FF_ATI + break; + +#ifdef GPRS + case WAP_GPRS_DATA: + { + /* GPRS call - attach now. If attached, connect. + * If not, wait until attach succeeds */ + + T_CGATT_STATE regstate; + + /* Check to see if attached */ + + qAT_PlusCGATT ( CMD_SRC_LCL, ®state ); +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("Reg state: %d", regstate); +#endif + + /* If we're not attached, attempt to do so */ + + if (regstate!=CGATT_STATE_ATTACHED) + { + /* Display status "attaching" */ + ATB_wap_status_change(View, ATB_WAP_ATTACHING); + /* Attempt to attach */ + sAT_PlusCGATT ( CMD_SRC_LCL, CGATT_STATE_ATTACHED ); + } + /* Otherwise, go straight to GPRS connection */ + else + { + connect_gprs(parameter->object_id); + } + } +#endif + } + + return; +} + + +#endif /* ! #ifdef FF_GPF_TCPIP */ + +#ifdef GPRS +#ifdef FF_GPF_TCPIP +extern void M4_DebugStringMessage(char *in_string, UINT8 ucNumber,unsigned long para); +void PowerOnGPRSAttach(void) +{ + T_CGATT_STATE regstate; + char temp[50]; + + /* Modified to detect if GPRS attach fails. Check to see if attached */ + qAT_PlusCGATT ( CMD_SRC_LCL, ®state ); + + sprintf(temp, "PowerOnGPRSAttach called!"); + //M4_DebugStringMessage( temp,(strlen(temp)), 0); + + /* If we're not attached, attempt to do so */ + if (regstate!=CGATT_STATE_ATTACHED) + { + sprintf(temp, "sAT_PlusCGATT called!"); + //M4_DebugStringMessage( temp,(strlen(temp)), 0); + + /* Attempt to attach */ + sAT_PlusCGATT ( CMD_SRC_LCL, CGATT_STATE_ATTACHED ); + } +} + +void mms_gprs_deattach(void) +{ + T_CGATT_STATE regstate; + char temp[50]; + + sprintf(temp, "mms_gprs_deattach called!"); + //M4_DebugStringMessage( temp,(strlen(temp)), 0); + + qAT_PlusCGATT ( CMD_SRC_LCL, ®state ); + + if (regstate == CGATT_STATE_ATTACHED) + { + sprintf(temp, "mms_gprs_deattach need to deattach!"); + //M4_DebugStringMessage( temp, (strlen(temp)), 0); + + /* Attempt to deattach */ + sAT_PlusCGATT ( CMD_SRC_LCL, CGATT_STATE_DETACHED ); + rvf_delay(100); + } + + return; +} + +void mms_gprs_attach(void) +{ + T_CGATT_STATE regstate; + char temp[50]; + UINT8 i; + UINT8 ucAttachTime; + + /* Modified to detect if GPRS attach fails. Check to see if attached */ + qAT_PlusCGATT ( CMD_SRC_LCL, ®state ); + TRACE_EVENT_P1("Reg state: %d", regstate); + + sprintf(temp, "mms_gprs_attach called!"); + //M4_DebugStringMessage( temp,(strlen(temp)), 0); + + /* If we're not attached, attempt to do so */ + if (regstate!=CGATT_STATE_ATTACHED) + { + sprintf(temp, "sAT_PlusCGATT called!"); + //M4_DebugStringMessage( temp,(strlen(temp)), 0); + + /* Attempt to attach */ + sAT_PlusCGATT ( CMD_SRC_LCL, CGATT_STATE_ATTACHED ); + + ucAttachTime = 24; + + for (i = 0;i < ucAttachTime;i++)//120s for GPRS + { + qAT_PlusCGATT ( CMD_SRC_LCL, ®state ); + if (regstate == CGATT_STATE_ATTACHED) + { + break; + } + + /*delay 5s*/ + rvf_delay(1000); + } + + if (i == ucAttachTime) + { + sprintf(temp, "mms_gprs_attach failed after 5s %03d* ",ucAttachTime); + //M4_DebugStringMessage( temp,(strlen(temp)), 0); + } + else + { + sprintf(temp, "mms_gprs_attach success!"); + //M4_DebugStringMessage( temp,(strlen(temp)), i); + } + } + +} + +/******************************************************************************* + + + $Function: connect_gprs + + $Description: GPRS is attached; now activate PDP context + SPR#1982 - SH + - Tidy up variables a little. + - Change '1' to GPRS_CID_1 + - Put traces inside #ifdefs + + $Returns: None. + + $Arguments: View - the current view + +*******************************************************************************/ + +void connect_gprs(UBYTE object_id) +{ + SHORT cids[MAX_CID_PLUS_EINS]; + BOOL states[MAX_CID_PLUS_EINS]; + T_GPRS_CONT_REC context; + T_ACI_RETURN ret; + T_WAP_VIEW *View; + SHORT contextId; + SHORT arrayPos; + char dialString[10]; + + TRACE_FUNCTION("connect_gprs()"); + + if (!(View = ATB_wap_get_view(object_id))) + return; + + /* Select the context ID */ + + contextId = GPRS_CID_1; + + + if (object_id==WAP_PUSH_VIEW) + { + contextId = GPRS_CID_2; + } + + + /* Check to see if context already active */ + memset (states, FALSE, sizeof(states)); + memset (cids, 0, sizeof(cids)); + + qAT_PlusCGACT ( CMD_SRC_LCL, states, cids ); + + if (contextId==cids[0] || cids[0]==INVALID_CID) + arrayPos = 0; + else + arrayPos = 1; + +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("Context 0: %d", cids[0]); +#endif + + /* If context doesn't exist, define it + * Use GPRS_CID_1 rather than number '1'*/ + + if ( cids[arrayPos] == INVALID_CID) + { +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("Defining new context."); +#endif + + states[arrayPos] = FALSE; + + strncpy((char *)context.apn, View->Profile->APN, MAX_APN_LEN); + strcpy((char*)context.pdp_type, "IP"); + memset(context.pdp_addr, '\0', MAX_PDP_ADDR_LEN); + context.d_comp = CGDCONT_D_COMP_OMITTED; + context.h_comp = CGDCONT_H_COMP_OMITTED; + memset(&context.qos, 0, sizeof(T_QOS)); + memset(&context.min_qos, 0 ,sizeof(T_QOS)); + + ret = sAT_PlusCGDCONT(CMD_SRC_LCL, contextId, &context); + +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("CGDCONT Return = %d",ret); +#endif + + if (ret==AT_FAIL) + { + ATB_wap_data_call_disconnected(View); + AUI_error_dialog(View, ERROR_GPRS_NOT_SUPPORTED); + return; + } + } + + /* Removed duplicate call to qAT_PlusCGACT. + * If context isn't activated, call CGPCO */ + + if (states[arrayPos]) + { +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("Context is activated."); +#endif + ATB_data_call_connected(View); /* SPR#2086 */ + } + else + { +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("Context not activated."); +#endif + + ret = sAT_PercentCGPCO ( + CMD_SRC_LCL, + contextId, + ACI_PCO_AUTH_PROT_PAP, + (CHAR *)View->Profile->Username, + (CHAR *)View->Profile->Password, + NULL, + NULL);//liuyu add NULL for build + +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("CGPCO Return = %d", ret); +#endif + + if (ret==AT_FAIL) + { + ATB_wap_data_call_disconnected(View); /* SPR#2086 */ + AUI_error_dialog(View, ERROR_GPRS_NOT_SUPPORTED); + return; + } + + //sprintf(dialString, "*98**1*%d#", contextId); + //"*98*1#" + //sAT_Dn(CMD_SRC_LCL,"*98*1#",D_CLIR_OVRD_Default,D_CUG_CTRL_NotPresent,D_TOC_Data); + ret = sAT_Dn( + CMD_SRC_LCL, + //dialString, + "*98*1#", + D_CLIR_OVRD_Default, + D_CUG_CTRL_NotPresent, + D_TOC_Data); + + switch (ret) + { + case (AT_CMPL): /*operation completed*/ + case (AT_EXCT): + break; + + default: + ATB_wap_data_call_disconnected(View); + AUI_error_dialog(View, ERROR_CALL_DISCONNECTED); + #ifdef TRACE_ATBWAPACI + TRACE_EVENT("Error occurred in connection."); + #endif + return; + break; + } + } + + return; + } +#else /* #ifdef FF_GPF_TCPIP */ + +void connect_gprs(UBYTE object_id) +{ + SHORT cids[MAX_CID_PLUS_EINS]; + BOOL states[MAX_CID_PLUS_EINS]; + T_GPRS_CONT_REC context; + T_ACI_RETURN ret; + UBYTE minsize; + T_WAP_VIEW *View; + + TRACE_FUNCTION("connect_gprs()"); + + if (!(View = ATB_wap_get_view(object_id))) + return; + + /* Check to see if context already active */ + memset (states, FALSE, sizeof(states)); + memset (cids, 0, sizeof(cids)); + + qAT_PlusCGACT ( CMD_SRC_LCL, states, cids ); + +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("Context 0: %d", cids[0]); +#endif + + /* If context doesn't exist, define it */ + + if ( cids[0] == INVALID_CID) + { +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("Defining new context."); +#endif + /* SPR#2138 - SH - If context not defined, it is not activated */ + states[0] = FALSE; + } + + /* SPR#2415 - SH - Define context, whether or not it was defined before */ + + minsize = (MAX_APN_LEN<(URL_MAX_LEN+1))?MAX_APN_LEN:(URL_MAX_LEN+1); + memset(&context.apn,'\0',MAX_APN_LEN); + memcpy(&context.apn,&View->Profile->APN,minsize); + strcpy((char*)context.pdp_type,"IP"); + minsize = (MAX_PDP_ADDR_LEN<(IPADDRESS_MAX_LEN+1))?MAX_PDP_ADDR_LEN:(IPADDRESS_MAX_LEN+1); + memset(&context.pdp_addr,'\0',MAX_PDP_ADDR_LEN); + context.d_comp = CGDCONT_D_COMP_OMITTED; + context.h_comp = CGDCONT_H_COMP_OMITTED; + memset(&context.qos,0,sizeof(T_QOS)); + memset(&context.min_qos,0,sizeof(T_QOS)); + + ret = sAT_PlusCGDCONT(CMD_SRC_LCL,GPRS_CID_1,&context); + +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("CGDCONT Return = %d",ret); +#endif + + if (ret==AT_FAIL) + { + AUI_error_dialog(View, ERROR_GPRS_NOT_SUPPORTED); + return; + } + + /* Removed duplicate call to qAT_PlusCGACT. + * If context isn't activated, call CGPCO */ + + if (states[0]) + { +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("Context is activated."); +#endif + ATB_data_call_connected(); /* SPR#2138 */ + } + else + { +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("Context not activated."); +#endif + + ret = sAT_PercentCGPCO ( + CMD_SRC_LCL, + GPRS_CID_1, + ACI_PCO_AUTH_PROT_PAP, + (CHAR *)View->Profile->Username, + (CHAR *)View->Profile->Password, + NULL, + NULL + ); + +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("CGPCO Return = %d", ret); +#endif + + if (ret==AT_FAIL) + { + AUI_error_dialog(View, ERROR_GPRS_NOT_SUPPORTED); + return; + } + + ret = sAT_Dn(CMD_SRC_LCL,"*98*1#",D_CLIR_OVRD_Default,D_CUG_CTRL_NotPresent,D_TOC_Data); + + switch (ret) + { + case (AT_CMPL): /*operation completed*/ + case (AT_EXCT): + break; + + default: + AUI_error_dialog(View, ERROR_CALL_DISCONNECTED); + #ifdef TRACE_ATBWAPACI + TRACE_EVENT("Error occurred in connection."); + #endif + return; + break; + } + + return; + } +} + +#endif /* #ifdef FF_GPF_TCPIP */ +#endif + +// xreddymn May-15-2005 MMI-SPR-30962: external functions +extern void MMS_set_WAP_busy(void); +extern void MMS_reset_WAP_busy(void); +extern void MMS_process_push_queue(void); + +/******************************************************************************* + + + $Function: M_WAP_MMI_DISCONNECTED_IND + + $Description: A disconnection has occurred. + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_DISCONNECTED_IND(T_WAP_MMI_DISCONNECTED_IND *parameter) +{ + T_WAP_VIEW *View; + +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_DISCONNECTED_IND"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif +#ifdef FF_GPF_TCPIP + // xreddymn Feb-23-2005 MMI-SPR-26144 + AUI_mms_cancel_status(); +#endif + if (!(View = ATB_wap_get_view(parameter->object_id))) + return; + + /* SPR#1816 - SH - Check if we're shutting down */ + + if (ATB_wap_status_get(View, ATB_WAP_SHUTTING_DOWN)) + { + TRACE_EVENT("*** SHUTTING DOWN ***"); + return; + } + +#ifdef FF_GPF_TCPIP + // xreddymn Feb-17-2005 MMI-SPR-26144: Disabled info dialogs + // as they appear when sending MMS + if(ATB_WAP_ATTACH_FAILED == parameter->error) + { + //xrashmic 08 Feb, 2005 MMI-SPR-27853 + //Need to indicate the BMI when there are GPRS errors + ATB_wap_status_change(View, ATB_WAP_ATTACH_FAILED); + } + else if(ATB_WAP_ACTIVATE_FAILED == parameter->error) + { + //xrashmic 08 Feb, 2005 MMI-SPR-27853 + //Need to indicate the BMI when there are GPRS errors + ATB_wap_status_change(View, ATB_WAP_ACTIVATE_FAILED); + } +#endif + + /* SPR#1574 - SH - Removed parameter */ + ATB_wap_status_change(View,ATB_WAP_ONLINE_CONNECTION_CLOSED); + +#ifdef FF_GPF_TCPIP + // xreddymn May-15-2005 MMI-SPR-30962: If MMS transaction is complete, + // clear WAP busy state. + MMS_reset_WAP_busy(); + MMS_process_push_queue(); +#endif + + return; +} + + +/******************************************************************************* + + + $Function: M_WAP_MMI_READY_CNF + + $Description: SPR#1569 - SH - Added this function + Confirm that WAP has completed the operation. + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_READY_CNF(T_WAP_MMI_READY_CNF *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_READY_CNF"); + TRACE_EVENT_P1("Event id = %d", parameter->event_id); +#endif + + switch (parameter->event_id) + { + case WAP_START_IND_ID: + ATB_wap_start_done(); + break; + case WAP_NEW_VIEW_IND_ID: + ATB_wap_new_view_done(); + break; + case WAP_CLOSE_VIEW_IND_ID: + ATB_wap_close_view_done(); + break; + case WAP_TERMINATE_IND_ID: + ATB_wap_terminate_done(); + break; + /* SPR#1824 - SH - Cache is prepared */ + case WAP_CACHE_PREPARE_IND_ID: + ATB_wap_cache_prepare_done(); + break; + } + return; +} + + +/******************************************************************************* + + $Function: disconnect_wap_call + + $Description: Disconnect GPRS WAP call in progress. + + $Returns: SPR#1982 - SH + TRUE if connection is disconnected, FALSE if disconnection in progress + + $Arguments: access_type - WAP_GPRS_DATA or WAP_CS_DATA + +*******************************************************************************/ + +UBYTE disconnect_wap_call(UBYTE access_type) +{ + UBYTE disconnected; + T_ACI_RETURN ret; +#ifdef GPRS + SHORT cids[MAX_CID_PLUS_EINS] = {GPRS_CID_1, INVALID_CID}; +#endif + + TRACE_FUNCTION("disconnect_wap_call()"); + + disconnected = TRUE; + +#ifdef GPRS + if (access_type==WAP_GPRS_DATA) + { + /* SPR#1875 - SH - Update data counter */ + + sAT_PercentSNCNT(CMD_SRC_LCL, TRUE); + + ret = sAT_PlusCGACT(CMD_SRC_LCL, CGACT_STATE_DEACTIVATED, cids); + +#ifdef TRACE_ATBWAPACI + TRACE_EVENT_P1("Result of sAT_PlusCGACT = %d", ret); +#endif + + /* If detaching will take a little time, show a please wait dialog */ + + if (ret==AT_EXCT) + { + disconnected = FALSE; + } + } +#endif + return disconnected; +} + +#ifdef FF_GPF_TCPIP +/******************************************************************************* + + + $Function: M_WAP_MMI_CONFIG_REQ + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_CONFIG_REQ(T_WAP_MMI_CONFIG_REQ *parameter) +{ + T_MMI_WAP_CONFIG_CNF parameter2; + T_WAP_VIEW *View; + T_WAP_PROFILE *httpClientProfile; + + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_CONFIG_REQ"); + TRACE_EVENT_P1("MMI object ID: %d",parameter->object_id); +#endif + + parameter2.object_id = parameter->object_id; + + /* Check if any view exists, create a new invisible view if not */ + + if (!(View = ATB_wap_get_view(parameter->object_id))) + { + View = ATB_wap_new_view_invisible(parameter->object_id); + ATB_wap_change_view(parameter->object_id); + } + + ATB_wap_profile_send(View); + + /* Set default channel */ + ATB_wap_config_int(View, configDEFAULT_CHANNEL, View->channel); + + /* Setup stack mode */ + httpClientProfile = View->Profile; + if (httpClientProfile->Port1 == 9201) + { + ATB_wap_conn_config_int(View, configCONNECTION_TYPE, CONNECTION_TYPE_WSP_CO); + TRACE_EVENT("CONNECTION_TYPE_WSP_CO at the location 2 called"); + } + else + { + ATB_wap_conn_config_int(View, configCONNECTION_TYPE, CONNECTION_TYPE_TCP); + TRACE_EVENT("CONNECTION_TYPE_TCP at the location 2 called"); + } + + + /* Set connection port */ + ATB_wap_conn_config_int(View, configCLIENT_PORT, WAP_DOWNLOAD_LOCAL_PORT); + + /* Set online status (FALSE = not always online) */ + //ATB_wap_conn_config_int(View, configONLINE, FALSE); + + parameter2.success = TRUE; + + M_MMI_WAP_CONFIG_CNF(¶meter2); + + return; +} + + +/******************************************************************************* + + $Function: M_WAP_MMI_CONTENT_IND + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_CONTENT_IND(T_WAP_MMI_CONTENT_IND *parameter) +{ + T_MMI_WAP_CONTENT_CNF parameter2; + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("W_WAP_MMI_CONTENT_IND"); + TRACE_EVENT_P2("URL ID: %d, data length = %d", parameter->urlID, parameter->data_length); + TRACE_EVENT_P2("moreData: %d, totalSize = %d", parameter->moreData, parameter->totalSize); +#endif + + ATB_wap_content( + parameter->urlID, + parameter->Data, + parameter->data_length, + parameter->moreData | parameter->moreSegments, + parameter->ContentType, + parameter->contentType_length, + parameter->totalSize, + parameter->errorNo + ); + + if (parameter->moreSegments==FALSE && parameter->moreData==TRUE) + { + TRACE_EVENT("Fetching more data"); + parameter2.urlID = parameter->urlID; + M_MMI_WAP_CONTENT_CNF(¶meter2); + } + + return; +} + +/******************************************************************************* + + $Function: M_WAP_MMI_CONTENT_POST_CNF + + $Description: SPR#2086 - SH - SAR + + $Returns: None + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_CONTENT_POST_CNF(T_WAP_MMI_CONTENT_POST_CNF *parameter) +{ + extern void mms_proc_content_post_cnf(UINT8 urlID); + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_CONTENT_POST_CNF"); + TRACE_EVENT_P1("urlID = %d", parameter->urlID); +#endif + + //TISHMMS Project + ////xmzhou_trace_string_value("M_WAP_MMI_CONTENT_POST_CNF called parameter->urlID = ", parameter->urlID); + mms_proc_content_post_cnf(parameter->urlID); + return; +} + +/******************************************************************************* + + $Function: copy_IP_address + + $Description: Copies IP address from one string to another. Ensures that the + destination string is in the form: AAA.BBB.CCC.DDD + + $Returns: None + + $Arguments: dst: Pointer to the destination string. On returning from this + function, this will contain the form: AAA.BBB.CCC.DDD + src: Pointer to the source string. This is a string representing + an IP address, where each field is seperated by a Dot (.) + + xreddymn Jan-24-2005 MMI-SPR-28135: WAP_OTA + +*******************************************************************************/ + +void copy_IP_address(char *dst, char *src, S32 length) +{ + S32 i=0, j, k=0, count, number; + U8 number_string[8]; + for(count=0;count<4;count++) + { + j=0; + while((src[i]!='\0') && (src[i]!='.') && (j<4)) + { + number_string[j]=src[i]; + i++; + j++; + } + if(src[i]=='.') i++; + number_string[j]='\0'; + number=atoi((char*)number_string); + if(count==3) sprintf((char*)&dst[k],"%03d",number); + else sprintf((char*)&dst[k],"%03d.",number); + k+=4; + } +} + +void M_WAP_MMI_BROWSER_SET_CSD_IND(T_WAP_MMI_BROWSER_SET_CSD_IND *parameter) +{ + T_WAP_PROFILE new_profile; + S32 length; +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_BROWSER_SET_CSD_IND"); + TRACE_EVENT_P1("Profile name = %s", parameter->OTA_profileName); + TRACE_EVENT_P1("Homepage URL = %s", parameter->OTA_homepageUrl); + TRACE_EVENT_P1("Dialstring = %s", parameter->OTA_CSD_dialstring); + TRACE_EVENT_P1("Proxy = %s", parameter->OTA_proxy); + TRACE_EVENT_P1("Port = %d", parameter->OTA_port); +#endif + // xreddymn Jan-24-2005 MMI-SPR-28135: WAP_OTA settings saved in WAP profiles + new_profile.AccessType=WAP_CS_DATA; + if(parameter->OTA_profileName_length==0) + { + ATB_convert_String((char*)"No name", MFW_ASCII, strlen("No name"), + (char*)new_profile.Title, MFW_DCS_UCS2, CARD_TITLE_MAX_LEN, TRUE); + } + else + { + ATB_convert_String((char*)parameter->OTA_profileName, MFW_ASCII, parameter->OTA_profileName_length, + (char*)new_profile.Title, MFW_DCS_UCS2, CARD_TITLE_MAX_LEN, TRUE); + } + length=parameter->OTA_homepageUrl_length; + if(length>(URL_MAX_LEN+1)) length=URL_MAX_LEN+1; + strncpy(new_profile.Homepage,parameter->OTA_homepageUrl,length); + new_profile.ConnectionType=WAP_CONTINUOUS; + if((strncmp(parameter->OTA_CSD_callType,"ISDN",parameter->OTA_CSD_callType_length)==0) || (strncmp(parameter->OTA_CSD_callType,"isdn",parameter->OTA_CSD_callType_length)==0)) + { + new_profile.ConnectionSpeed=WAP_ISDN9600; + } + else + { + new_profile.ConnectionSpeed=WAP_ANALOGUE; + } + new_profile.ResponseTimer=60; + new_profile.Port1=parameter->OTA_port; + new_profile.Port2=parameter->OTA_port; + length=parameter->OTA_proxy_length; + if(length>(IPADDRESS_MAX_LEN+1)) length=IPADDRESS_MAX_LEN+1; + copy_IP_address(new_profile.IPAddress1,parameter->OTA_proxy,length); + copy_IP_address(new_profile.IPAddress2,parameter->OTA_proxy,length); + length=parameter->OTA_CSD_dialstring_length; + if(length>(NUMBER_MAX_LEN+1)) length=NUMBER_MAX_LEN+1; + strncpy(new_profile.DialupNumber,parameter->OTA_CSD_dialstring,length); + length=parameter->OTA_PPP_username_length; + if(length==0) + { + strcpy(new_profile.Username,""); + } + else + { + if(length>(USERNAME_MAX_LEN+1)) length=USERNAME_MAX_LEN+1; + strncpy(new_profile.Username,parameter->OTA_PPP_username,length); + } + length=parameter->OTA_PPP_password_length; + if(length==0) + { + strcpy(new_profile.Password,""); + } + else + { + if(length>(PASSWORD_MAX_LEN+1)) length=PASSWORD_MAX_LEN+1; + strncpy(new_profile.Password,parameter->OTA_PPP_password,length); + } + new_profile.Security=FALSE; + strcpy(new_profile.NameServer1,""); + strcpy(new_profile.NameServer2,""); + new_profile.PPGAuthentication=FALSE; + new_profile.WirelessProfiledHTTP=TRUE; + ATB_wap_profile_add(&new_profile); + return; +} + +void M_WAP_MMI_BROWSER_SET_GPRS_IND(T_WAP_MMI_BROWSER_SET_GPRS_IND *parameter) +{ + T_WAP_PROFILE new_profile; + S32 length; +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_BROWSER_SET_GPRS_IND"); + TRACE_EVENT_P1("Profile name = %s", parameter->OTA_profileName); + TRACE_EVENT_P1("Homepage URL = %s", parameter->OTA_homepageUrl); + TRACE_EVENT_P1("APN = %s", parameter->OTA_GPRS_APN); + TRACE_EVENT_P1("Proxy = %s", parameter->OTA_proxy); + TRACE_EVENT_P1("Port = %d", parameter->OTA_port); +#endif + // xreddymn Jan-24-2005 MMI-SPR-28135: WAP_OTA settings saved in WAP profiles + new_profile.AccessType=WAP_GPRS_DATA; + if(parameter->OTA_profileName_length==0) + { + ATB_convert_String((char*)"No name", MFW_ASCII, strlen("No name"), + (char*)new_profile.Title, MFW_DCS_UCS2, CARD_TITLE_MAX_LEN, TRUE); + } + else + { + ATB_convert_String((char*)parameter->OTA_profileName, MFW_ASCII, parameter->OTA_profileName_length, + (char*)new_profile.Title, MFW_DCS_UCS2, CARD_TITLE_MAX_LEN, TRUE); + } + length=parameter->OTA_homepageUrl_length; + if(length>(URL_MAX_LEN+1)) length=URL_MAX_LEN+1; + strncpy(new_profile.Homepage,parameter->OTA_homepageUrl,length); + new_profile.ConnectionType=WAP_CONTINUOUS; + new_profile.ResponseTimer=60; + new_profile.Port1=parameter->OTA_port; + new_profile.Port2=parameter->OTA_port; + length=parameter->OTA_proxy_length; + if(length>(IPADDRESS_MAX_LEN+1)) length=IPADDRESS_MAX_LEN+1; + copy_IP_address(new_profile.IPAddress1,parameter->OTA_proxy,length); + copy_IP_address(new_profile.IPAddress2,parameter->OTA_proxy,length); + length=parameter->OTA_GPRS_APN_length; + if(length>(URL_MAX_LEN+1)) length=URL_MAX_LEN+1; + strncpy(new_profile.APN,parameter->OTA_GPRS_APN,length); + length=parameter->OTA_proxy_username_length; + if(length==0) + { + strcpy(new_profile.Username,""); + } + else + { + if(length>(USERNAME_MAX_LEN+1)) length=USERNAME_MAX_LEN+1; + strncpy(new_profile.Username,parameter->OTA_proxy_username,length); + } + length=parameter->OTA_proxy_password_length; + if(length==0) + { + strcpy(new_profile.Password,""); + } + else + { + if(length>(PASSWORD_MAX_LEN+1)) length=PASSWORD_MAX_LEN+1; + strncpy(new_profile.Password,parameter->OTA_proxy_password,length); + } + new_profile.Security=FALSE; + strcpy(new_profile.NameServer1,""); + strcpy(new_profile.NameServer2,""); + new_profile.PPGAuthentication=FALSE; + new_profile.WirelessProfiledHTTP=TRUE; + ATB_wap_profile_add(&new_profile); + return; +} + + +void M_WAP_MMI_MMS_SET_CSD_IND(T_WAP_MMI_MMS_SET_CSD_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_MMS_SET_CSD_IND"); + TRACE_EVENT_P1("Profile name = %s", parameter->OTA_profileName); + TRACE_EVENT_P1("MMSC URL = %s", parameter->OTA_mmsUrl); + TRACE_EVENT_P1("Dialstring = %s", parameter->OTA_CSD_dialstring); + TRACE_EVENT_P1("Proxy = %s", parameter->OTA_proxy); + TRACE_EVENT_P1("Port = %d", parameter->OTA_port); +#endif + + return; +} + +void M_WAP_MMI_MMS_SET_GPRS_IND(T_WAP_MMI_MMS_SET_GPRS_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_MMS_SET_GPRS_IND"); + TRACE_EVENT_P1("Profile name = %s", parameter->OTA_profileName); + TRACE_EVENT_P1("MMSC URL = %s", parameter->OTA_mmsUrl); + TRACE_EVENT_P1("APN = %s", parameter->OTA_GPRS_APN); + TRACE_EVENT_P1("Proxy = %s", parameter->OTA_proxy); + TRACE_EVENT_P1("Port = %d", parameter->OTA_port); +#endif + + return; +} + +void M_WAP_MMI_BROWSER_BOOKMARKS_IND(T_WAP_MMI_BROWSER_BOOKMARKS_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_BROWSER_BOOKMARKS_IND"); + TRACE_EVENT_P1("Number of bookmarks = %d", parameter->OTA_numberOfBookmarks); + TRACE_EVENT_P1("First bookmark name = %s", parameter->OTA_bookmarkName_1); + TRACE_EVENT_P1("First bookmark url = %s", parameter->OTA_bookmarkUrl_1); +#endif + + return; +} +void M_WAP_MMI_SYNCML_GENERAL_SET_IND(T_WAP_MMI_SYNCML_GENERAL_SET_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_SYNCML_GENERAL_SET_IND"); + TRACE_EVENT_P1("Host address = %s", parameter->OTASYNC_HostAddr); + TRACE_EVENT_P1("Database URI = %s", parameter->OTASYNC_URI); + TRACE_EVENT_P1("Connection port = %d", parameter->OTASYNC_Port); +#endif + + return; +} + +void M_WAP_MMI_SYNCML_CONTENT_SET_IND(T_WAP_MMI_SYNCML_CONTENT_SET_IND *parameter) +{ + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_SYNCML_CONTENT_SET_IND"); + TRACE_EVENT_P1("Content type = %s", parameter->OTASYNC_CTType); + TRACE_EVENT_P1("Content version = %s", parameter->OTASYNC_CTVer); +#endif + + return; +} +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_NEW_SI_IND + + $Description: New SI is received + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_NEW_SI_IND(T_WAP_MMI_PUSH_NEW_SI_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("M_WAP_MMI_PUSH_NEW_SI_IND"); +#endif + + ATB_wap_push_SI_new( + parameter->id, + parameter->created, + parameter->expires, + parameter->Message, + parameter->message_length, + parameter->expired, + parameter->Url, + parameter->url_length, + parameter->priority, + parameter->InitURL, + parameter->initURL_length, + parameter->applicationType, + parameter->newChannelId ); + + return; +} + +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_SI_INFO_IND + + $Description: SI info is received + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_SI_INFO_IND(T_WAP_MMI_PUSH_SI_INFO_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("M_WAP_MMI_PUSH_SI_INFO_IND"); +#endif + + ATB_wap_push_SI_info( + parameter->id, + parameter->status, + parameter->created, + parameter->expires, + parameter->Message, + parameter->message_length, + parameter->expired, + parameter->Url, + parameter->url_length, + parameter->priority, + parameter->InitURL, + parameter->initURL_length); + + return; +} + +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_NEW_SL_IND + + $Description: New SL is received + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_NEW_SL_IND(T_WAP_MMI_PUSH_NEW_SL_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("M_WAP_MMI_PUSH_NEW_SL_IND"); +#endif + + // xreddymn Mar-22-2005 MMI-SPR-29767: Modified handling of SL messages + // xreddymn Mar-11-2005 MMI-SPR-29510: Enabled support for SL messages + ATB_wap_push_SL_new( + parameter->id, + parameter->Url, + parameter->url_length, + parameter->priority, + parameter->InitURL, + parameter->initURL_length, + parameter->applicationType, + parameter->newChannelId ); + + return; +} + +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_SL_INFO_IND + + $Description: SL info is received + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_SL_INFO_IND(T_WAP_MMI_PUSH_SL_INFO_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("M_WAP_MMI_PUSH_SL_INFO_IND"); +#endif + + + return; +} + +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_MESSAGE_CHANGE_IND + + $Description: A message status has changed + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_MESSAGE_CHANGE_IND(T_WAP_MMI_PUSH_MESSAGE_CHANGE_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("M_WAP_MMI_PUSH_MESSAGE_CHANGE_IND"); +#endif + + return; +} + + +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_REPOSITORY_FULL_IND + + $Description: The push repository is full + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_REPOSITORY_FULL_IND(T_WAP_MMI_PUSH_REPOSITORY_FULL_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("M_WAP_MMI_PUSH_REPOSITORY_FULL_IND"); +#endif + + return; +} + + +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_CONNECTION_REQ + + $Description: A request to set up the push connection + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_CONNECTION_REQ(T_WAP_MMI_PUSH_CONNECTION_REQ *parameter) +{ + T_MMI_WAP_PUSH_CONNECTION_CNF parameter2; + T_WAP_VIEW *View; + ULONG IPAddressLong; + +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_PUSH_CONNECTION_REQ"); +#endif + + /* Check if any view exists, create a new invisible view if not */ + + if (!(View = ATB_wap_get_view(PUSH_USER_AGENT))) + { + View = ATB_wap_new_view_invisible(PUSH_USER_AGENT); + } + + /* Setup stack mode */ + ATB_wap_conn_config_int(View, configACCESS_TYPE, parameter->stackMode); + + /* Setup access type- CSD by default */ + if (parameter->accessType!=BEARER_ANY) + { + ATB_wap_conn_config_int(View, configACCESS_TYPE, parameter->accessType); + } + else + { + ATB_wap_conn_config_int(View, configACCESS_TYPE, BEARER_GSM_CSD); + } + + /* Setup gateway address */ + ATB_conv_str_to_IP(parameter->Address, parameter->address_length, &IPAddressLong); + ATB_wap_conn_config_str(View, configPROXY_ADDRESS, (CHAR *)&IPAddressLong, sizeof(ULONG)); + + /* Set connection port */ + ATB_wap_conn_config_int(View, configCLIENT_PORT, WAP_LOCAL_PORT); + + /* Set online status (FALSE = not always online) */ + //ATB_wap_conn_config_int(View, configONLINE, FALSE); + + /* Setup timeout */ + ATB_wap_conn_config_int(View, configTIMEOUT, WAP_DEFAULT_RESPONSE_TIME); + + /* Set connection port 1 */ + ATB_wap_conn_config_int(View, WAP_setPort1, WAP_DEFAULT_PORT); + + /* Set connection port 2 */ + ATB_wap_conn_config_int(View, WAP_setPort2, WAP_DEFAULT_PORT); + + ATB_wap_config_int(View, configPPG_AUTHENTICATION_REQUIRED, 0); + + parameter2.siaId = parameter->siaId; + parameter2.channelId = WAP_CHANNEL_ID; + parameter2.success = TRUE; + + M_MMI_WAP_PUSH_CONNECTION_CNF(¶meter2); + + return; +} + + +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_UNLOADED_MSG_CNF + + $Description: Indicates if there are unloaded messages in the Push inbox + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_UNLOADED_MSG_CNF(T_WAP_MMI_PUSH_UNLOADED_MSG_CNF *parameter) +{ + TRACE_FUNCTION("M_WAP_MMI_PUSH_UNLOADED_MSG_CNF"); + + return; +} + + +/******************************************************************************* + + $Function: M_WAP_MMI_PUSH_SMS_SEND_IND + + $Description: Request for MMI to send an SMS + SPR#2086 - Added + + $Returns: None + + $Arguments: parameter - Data block + +*******************************************************************************/ + +void M_WAP_MMI_PUSH_SMS_SEND_IND(T_WAP_MMI_PUSH_SMS_SEND_IND *parameter) +{ +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_WAP_MMI_PUSH_SMS_SEND_IND"); + TRACE_EVENT_P1("destination_length: %d", parameter->destination_length); + TRACE_EVENT_P1("data_length: %d", parameter->data_length); +#endif + + ATB_wap_push_SMS_send( + parameter->Smsc, + parameter->smsc_length, + parameter->Destination, + parameter->destination_length, + parameter->Data, + parameter->data_length); + + return; +} + +// xreddymn Mar-25-2005 MMI-SPR-26144: send data indication +// this is used to update progress when sending MMS +/******************************************************************************* + + $Function: M_WAP_MMI_NET_SEND_IND + + $Description: NET SEND indication + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_WAP_MMI_NET_SEND_IND(T_WAP_MMI_NET_SEND_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_FUNCTION("M_WAP_MMI_NET_SEND_IND"); +#endif +#ifdef FF_GPF_TCPIP + AUI_wap_net_send_ind(); +#endif +} + +// xreddymn MMI-SPR-30834 May-14-2005 +/******************************************************************************* + + $Function: M_MMI_WAP_FREE_MEM_IND + + $Description: Called by MMI to free data in WAP memory + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_FREE_MEM_IND(T_MMI_WAP_MEM_FREE_IND *parameter) +{ +#ifdef TRACE_ATBWAPACI + TRACE_EVENT("M_MMI_WAP_FREE_MEM_IND"); +#endif + + mmi_coder(WAP_MEM_FREE_IND_ID, (void *)parameter); + + return; +} + +// xreddymn Jun-21-2005 MMI-SPR-30291 +/******************************************************************************* + + $Function: M_MMI_WAP_SEND_PROFILE_IND + + $Description: Sends profile data from MMI to WAP adapter + + $Returns: None. + + $Arguments: parameter - data block + +*******************************************************************************/ + +void M_MMI_WAP_SEND_PROFILE_IND(T_MMI_WAP_SEND_PROFILE_IND *parameter) +{ +#ifdef TRACE_WAP_WAPMMI + TRACE_EVENT("M_MMI_WAP_SEND_PROFILE_IND"); +#endif + + mmi_coder(WAP_SEND_PROFILE_IND_ID, (void *)parameter); + + return; +} + +#endif +/* #ifdef FF_GPF_TCPIP */