view src/ui/mfw/mfw_BtipsOppc.c @ 70:032a561fab2b

GPF-Riviera sync: make MMI task startup wait for FCHG
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 23 Oct 2020 04:52:28 +0000
parents 67bfe9f274f6
children
line wrap: on
line source

/* =========================================================
*             Texas Instruments OMAP(TM) Platform Software
*  (c) Copyright Texas Instruments, Incorporated.  All Rights Reserved.
*
*  Use of this software is controlled by the terms and conditions found
*  in the license agreement under which this software has been supplied.
* ========================================================== */
/*
 $Project name: Basic Bluetooth MMI
 $Project code:
 $Module:   Bluetooth BMG MFW
 $File:       Mfw_BtipsOppc.c
 $Revision:   1.0
 $Author:   Texas Instruments
 $Date:       26/06/07

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

 Description:

    This module provides the OPP Client APPlication functionality.

********************************************************************************
 $History: Mfw_BtipsOppc.c

  26/06/07 Sasken original version

 $End

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




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

                                Include files

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

#define ENTITY_MFW
/* includes */

#include <string.h>

#if defined (NEW_FRAME)

#include "typedefs.h"
#include "vsi.h"
#include "pei.h"
#include "custom.h"
#include "gsm.h"
#include "prim.h"

#else

#include "STDDEFS.H"
#include "custom.h"
#include "gsm.h"
#include "vsi.h"

#endif

#ifdef FF_MMI_BTIPS_APP
#include "osapi.h"
#include "btl_common.h"
#include "debug.h"

//#include "../app_main.h"
#include "btl_oppc.h"
#include "btl_config.h"
#include "bthal_fs.h"
//#include "../../btl/inc/int/obstore.h"
#include "obstore.h"

#include "mfw_BtipsOppc.h"
#include "Mfw_mfw.h"
#include "mfw_Btips.h"
#include "mfw_ffs.h"

extern int   oppc_files_count;
//Array to load fileNames in content directory
extern char* oppc_file_names[OPPC_MAX_FILES]; 

/* Macro for sending events to UI - meanwhile, trace message to PCO Viewer */
extern int vsi_o_state_ttrace ( const char * const format, ... );
#define UI_DISPLAY(s) vsi_o_state_ttrace s

/********************************************************************************
 *
 * Constants 
 *
 *******************************************************************************/


/*******************************************************************************
 *
 * Macro definitions
 *
 ******************************************************************************/
#define OPPCA_BUFF_MAX                    (1 * 512)

#define BTL_CONFIG_OPP_MAX_FILE_NAME_LEN	min(GOEP_MAX_UNICODE_LEN/2-2, BTHAL_FS_MAX_FILE_NAME_LENGTH)


#define OPPCA_CHECK_FS_NAME_LEN(fsPath)    \
             (OS_StrLen(fsPath) < (BTL_CONFIG_OPP_MAX_FILE_NAME_LEN + BTHAL_FS_MAX_PATH_LENGTH + 1)) 





/*******************************************************************************
 *
 * OPPC External Function prototypes
 *
 ******************************************************************************/

void mfw_btips_oppcInit(void);
void mfw_btips_oppcDeinit(void);

void mfw_btips_oppcEncapsulatePush(const char *fsPushPath, BD_ADDR *bd_addr);
void mfw_btips_oppcEncapsulatePull(const char *fsPullPath, BD_ADDR *bd_addr);
void mfw_btips_oppcEncapsulateExchange(const char *fsPushPath, const char *fsPullPath, BD_ADDR *bd_addr);







/*-------------------------------------------------------------------------------
 * OppcaCurrOperation type
 *
 *     Defines the OPPCA current operation.
 */
typedef U8 OppcaCurrOperation;

#define OPPCA_OPER_NONE     		0x00	
#define OPPCA_OPER_BASIC_PULL		0x01	/* Pull */
#define OPPCA_OPER_BASIC_PUSH    	0x02	/* Push */
#define OPPCA_OPER_BASIC_EXCHANGE	0x03	/* Push-Pull */
#define OPPCA_OPER_ENC_PULL 		0x04	/* Connect-Pull-Disconnect */
#define OPPCA_OPER_ENC_PUSH 		0x05	/* Connect-Push-Disconnect */
#define OPPCA_OPER_ENC_EXCHANGE     0x06	/* Connect-Push-Pull-Disconnect */


/*-------------------------------------------------------------------------------
 * OppcaState type
 *
 *     Defines the OPPCA current state.
 */
typedef U8 OppcaState;

#define OPPCA_IDLE				0x00	/* OBEX and Transport disconnected */   
#define OPPCA_CONNECTING		0x01	/* OBEX connecting */
#define OPPCA_TP_CONNECTED		0x02	/* Transport connected */
#define OPPCA_CONNECTED			0x03	/* OBEX connected */
#define OPPCA_DISCONNECTING		0x04	/* OBEX disconnecting */   
#define OPPCA_TP_DISCONNECTING	0x05	/* Transport disconnecting */
#define OPPCA_DISABLING     	0x06	/* OBEX and Transport disabling */


typedef struct _OppcaData 
{
    OppcaState          state;

    BOOL                isConnected;

    BOOL 	            operationOngoing;

    BtSecurityLevel     securityLevel;

    BtlObjectLocation   objLocation;

    OppcaCurrOperation  currOper;

    /* Memory Objects */
    char                pushBuff[OPPCA_BUFF_MAX];
    char                pullBuff[OPPCA_BUFF_MAX];

} OppcaData;

 
/********************************************************************************
 *
 * Globals
 *
 *******************************************************************************/

static OppcaData    oppClient;
static BtlOppcContext   *oppcContext = 0;   

static char ObPushName[BTL_CONFIG_OPP_MAX_FILE_NAME_LEN + 1] = {'\0'};
static char ObPullName[BTL_CONFIG_OPP_MAX_FILE_NAME_LEN + 1] = {'\0'};

extern char push_file_name[];

/*******************************************************************************
 *
 * Internal Function prototypes
 *
 ******************************************************************************/
static void  btips_oppcCallback(const BtlOppcEvent *Event);

static const char *mfw_btips_oppcGoepOpName(GoepOperation Op);

static BOOL mfw_btips_oppcBuildPushObject(BtlObject *objToPush, const char *fsPath, char *buff);
static BOOL mfw_btips_oppcBuildPullObject(BtlObject *objToPull, const char *fsPath, char *buff);

static BOOL mfw_btips_oppcConvertToMemPushObject(BtlObject *obj, const char *fsPushPathh, char *buff);
static void mfw_btips_oppcSetFsPushObject(BtlObject *obj, const char *fsPushPath);
static void mfw_btips_oppcSetFsPullObject(BtlObject *obj, const char *fsPullPath);
static void mfw_btips_oppcSetMemPullObject(BtlObject *obj, const char *fsPullPath, char *buff);

/*---------------------------------------------------------------------------
 *            mfw_btips_oppcInit
 *---------------------------------------------------------------------------
 *
 * Synopsis:  Initialize the OBEX Client for the OPP application 
 *            and the Object Store.
 *
 * Return:    void
 *
 */
void mfw_btips_oppcInit(void)
{
    BtStatus status;
    
    oppClient.state = OPPCA_IDLE;
    oppClient.isConnected = FALSE;
    oppClient.operationOngoing = FALSE;
    oppClient.securityLevel = BSL_NO_SECURITY;
    oppClient.currOper = OPPCA_OPER_NONE;
    oppClient.objLocation = BTL_OBJECT_LOCATION_FS;
    
    status = BTL_OPPC_Create((BtlAppHandle *)0, btips_oppcCallback, &oppClient.securityLevel, &oppcContext);
    TRACE_EVENT_P1("BTL_OPPC_Create() returned %s.",pBT_Status(status));

    status = BTL_OPPC_Enable(oppcContext);
    TRACE_EVENT_P1("BTL_OPPC_Enable() returned %s.",pBT_Status(status));
}


/*---------------------------------------------------------------------------
 *            mfw_btips_oppcDeinit
 *---------------------------------------------------------------------------
 *
 * Synopsis:  Deinitialize the OBEX Client protocol.
 *
 * Return:    void
 *
 */
void mfw_btips_oppcDeinit(void)
{
	BtStatus status;

	status =  BTL_OPPC_Disable(oppcContext);
	
    Report(("BTL_OPPC_Disable() returned %s.",pBT_Status(status)));

    if (status == BT_STATUS_SUCCESS)
    {
    status = BTL_OPPC_Destroy(&oppcContext);
    
    Report(("BTL_OPPC_Destroy() returned %s.", pBT_Status(status)));

        oppClient.state = OPPCA_IDLE;
        oppClient.isConnected = FALSE;
        oppClient.operationOngoing = FALSE;
    }
    else
    {
        oppClient.state = OPPCA_DISABLING;
    }
}


/*---------------------------------------------------------------------------
 *            mfw_btips_oppcEncapsulatePush
 *---------------------------------------------------------------------------
 *
 * Synopsis:  Initiate an OBEX Object Push procedure.
 *            Includes Connect and Disconnect from the opp server.  
 *			  If the given BD_ADDR is NULL, a search is performed.
 *
 * Return:    void
 *
 */
void mfw_btips_oppcEncapsulatePush(const char *fsPushPath, BD_ADDR *bd_addr)
{
    BtStatus status;
	BtlObject objToPush;
	
	Report(("mfw_btips_oppcEncapsulatePush: fsPushPath = %s", fsPushPath));

    if (TRUE != OPPCA_CHECK_FS_NAME_LEN(fsPushPath))
	{
		Report(("mfw_btips_oppcEncapsulatePush: Can't push. fsPushPath too long"));
		return;
	}
	
    if (TRUE != mfw_btips_oppcBuildPushObject(&objToPush, fsPushPath, oppClient.pushBuff))
    {
        Report(("OPPCA_BasicPull: Can't pull"));
        return;
    }

    status = BTL_OPPC_ConnectPushDisconnect(oppcContext, bd_addr, &objToPush);

	Report(("BTL_OPPC_ConnectPushDisconnect() returned %s.", pBT_Status(status)));
	if (status == OB_STATUS_PENDING)
	{
		Report(("mfw_btips_oppcEncapsulatePush(): Started ..."));
		oppClient.operationOngoing = TRUE;
        oppClient.currOper = OPPCA_OPER_ENC_PUSH;
    }
}


/*---------------------------------------------------------------------------
 *            mfw_btips_oppcEncapsulatePull
 *---------------------------------------------------------------------------
 *
 * Synopsis:  Initiate an OBEX Business Card Pull procedure.
 *            Includes Connect and Disconnect from the opp server.  
 *			  If the given BD_ADDR is NULL, a search is performed.
 *
 * Return:    void
 *
 */
void mfw_btips_oppcEncapsulatePull(const char *fsPullPath, BD_ADDR *bd_addr)
{
    BtStatus status;
	BtlObject objToPull;
	
    Report(("mfw_btips_oppcEncapsulatePull: fsPullPath = %s", fsPullPath));
   
    if (TRUE != OPPCA_CHECK_FS_NAME_LEN(fsPullPath))
	{
		Report(("mfw_btips_oppcEncapsulatePull: Can't pull. fsPullPath too long"));
		return;
	}
     
    if (TRUE != mfw_btips_oppcBuildPullObject(&objToPull, fsPullPath, oppClient.pullBuff))
    {
        Report(("mfw_btips_oppcEncapsulatePull: Can't pull"));
        return;
    }
    
	status = BTL_OPPC_ConnectPullDisconnect(oppcContext, bd_addr, &objToPull);
	
	Report(("BTL_OPPC_Pull() returned %s.", pBT_Status(status)));
		
	if (status == OB_STATUS_PENDING)
	{
		Report(("mfw_btips_oppcEncapsulatePull(): Started ..."));
		oppClient.operationOngoing = TRUE;
        oppClient.currOper = OPPCA_OPER_ENC_PULL;
    }
}


/*---------------------------------------------------------------------------
 *            mfw_btips_oppcEncapsulateExchange
 *---------------------------------------------------------------------------
 *
 * Synopsis:  Initiate an OBEX Business Card Exchange procedure.
 *            Includes Connect and Disconnect from the opp server.  
 *			  If the given BD_ADDR is NULL, a search is performed.
 *
 * Return:    void
 *
 */
void mfw_btips_oppcEncapsulateExchange(const char *fsPushPath, const char *fsPullPath, BD_ADDR *bd_addr)
{
    BtStatus status;
	BtlObject objToPush, objToPull;
	
	Report(("mfw_btips_oppcEncapsulateExchange: fsPushPath = %s, fsPullPath = %s", fsPushPath, fsPullPath));


	/* -------- Push Operation --------- */
    
    if (TRUE != OPPCA_CHECK_FS_NAME_LEN(fsPushPath))
	{
		Report(("mfw_btips_oppcEncapsulateExchange: Can't push. fsPushath too long"));
		return;
	}

	if (TRUE != mfw_btips_oppcBuildPushObject(&objToPush, fsPushPath, oppClient.pushBuff))
    {
        Report(("mfw_btips_oppcEncapsulateExchange: Can't push"));
        return;
    }
   
	/* -------- Pull Operation --------- */

    if (TRUE != OPPCA_CHECK_FS_NAME_LEN(fsPullPath))
	{
		Report(("mfw_btips_oppcEncapsulateExchange: Can't pull. fsPullPath too long"));
		return;
	}

    if (TRUE != mfw_btips_oppcBuildPullObject(&objToPull, fsPullPath, oppClient.pullBuff))
    {
        Report(("mfw_btips_oppcEncapsulateExchange: Can't pull"));
        return;
    }

    
    status = BTL_OPPC_ConnectExchangeDisconnect(oppcContext, bd_addr, &objToPush, &objToPull);

	Report(("BTL_OPPC_ConnectExchangeDisconnect() returned %s.", pBT_Status(status)));
	
	if (status == OB_STATUS_PENDING)
	{
		Report(("mfw_btips_oppcEncapsulateExchange(): Started ..."));
		oppClient.operationOngoing = TRUE;
        oppClient.currOper = OPPCA_OPER_ENC_EXCHANGE;
    }
}	


/*---------------------------------------------------------------------------
 *            btips_oppcCallback
 *---------------------------------------------------------------------------
 *
 * Synopsis:  This function processes OBEX Client protocol events.
 *
 * Return:    void
 *
 */
static void btips_oppcCallback(const BtlOppcEvent *Event)
{
    BD_ADDR bdAddr;
	char addr[BDADDR_NTOA_SIZE];
    BtStatus status;

    switch (Event->oppcEvent->event)
	{
        case OPPC_EVENT_COMPLETE:
			
            TRACE_EVENT_P1("btips_oppcCallback: The current %s is complete.", mfw_btips_oppcGoepOpName(Event->oppcEvent->oper)); 

            switch (Event->oppcEvent->oper) 
		    {
                case GOEP_OPER_CONNECT:
                    TRACE_EVENT_P1("btips_oppcCallback: Transport Connection has been established with %s", bdaddr_ntoa(&bdAddr, addr));
                    BTL_OPPC_GetConnectedDevice(oppcContext, &bdAddr);
                    oppClient.state = OPPCA_CONNECTED;
                    oppClient.isConnected = TRUE;
                    break;
                    
                case GOEP_OPER_DISCONNECT:
                    TRACE_EVENT("btips_oppcCallback: Transport Connection has been disconnected.");
		    	oppClient.isConnected = FALSE;
			oppClient.state = OPPCA_IDLE;
                    oppClient.operationOngoing = FALSE;
                    break;


                case GOEP_OPER_PULL:

                    switch(oppClient.currOper)
                    {
                        case OPPCA_OPER_BASIC_PULL:
                            oppClient.operationOngoing = FALSE;
                            break;

                        case OPPCA_OPER_BASIC_EXCHANGE:
                            oppClient.operationOngoing = FALSE;
                            break;
                    }

                    break;


                case GOEP_OPER_PUSH:

                    switch(oppClient.currOper)
                    {
                        case OPPCA_OPER_BASIC_PUSH:
                            oppClient.operationOngoing = FALSE;
                            break;
                    }
                    break;
            }
            break;

        case OPPC_EVENT_ABORTED:
			
			UI_DISPLAY(("btips_oppcCallback: %s operation failed.", mfw_btips_oppcGoepOpName(Event->oppcEvent->oper))); 
			break;

        case OPPC_EVENT_TP_CONNECTED:
			
            BTL_OPPC_GetConnectedDevice(oppcContext, &bdAddr);
			UI_DISPLAY(("btips_oppcCallback: Transport Connection is up to %s.", bdaddr_ntoa(&bdAddr, addr)));

            oppClient.state = OPPCA_TP_CONNECTED;
            oppClient.isConnected = TRUE;
			break;

       	case OPPC_EVENT_TP_DISCONNECTED:
			
            UI_DISPLAY(("btips_oppcCallback: Transport Connection has been disconnected."));
            
            
			oppClient.isConnected = FALSE;
            oppClient.operationOngoing = FALSE;
            
            if (oppClient.state != OPPCA_DISABLING)
            {
            oppClient.state = OPPCA_IDLE; 
            }
			break;

        
        case OPPC_EVENT_DISCOVERY_FAILED:
			
            UI_DISPLAY(("btips_oppcCallback: Discovery Failure."));
			oppClient.state = OPPCA_IDLE;
			break;

     	case OPPC_EVENT_NO_SERVICE_FOUND:
			
            UI_DISPLAY(("btips_oppcCallback: No OBEX Service Found."));
			oppClient.state = OPPCA_IDLE;
			break;
		
	
	    case OPPC_EVENT_OBJECT_PROGRESS:
			
            UI_DISPLAY(("btips_oppcCallback: progress bar ..."));
            
            break;
   
    
        case OPPC_EVENT_DISABLED:
            
            UI_DISPLAY(("btips_oppcCallback: Receiving OPPC_EVENT_DISABLED."));
            
            if (OPPCA_DISABLING == oppClient.state)
            {
                status = BTL_OPPC_Destroy(&oppcContext);
    
                Report(("BTL_OPPC_Destroy() returned %s.", pBT_Status(status)));  
            }
            
            oppClient.state = OPPCA_IDLE;
            break;

        default:
		    
            UI_DISPLAY(("btips_oppcCallback: Unexpected event: %i", Event->oppcEvent->event));
            break;
    }
}


/*---------------------------------------------------------------------------
 *            mfw_btips_oppcGoepOpName
 *---------------------------------------------------------------------------
 *
 * Synopsis:  Return a pointer to the name of the current operation.
 *
 * Return:    ASCII String pointer.
 *
 */
static const char *mfw_btips_oppcGoepOpName(GoepOperation Op)
{
    switch (Op) 
	{
    case GOEP_OPER_PUSH:
        return "Push";
    case GOEP_OPER_PULL:
        return "Pull";
    case GOEP_OPER_CONNECT:
        return "Connect";
    case GOEP_OPER_DISCONNECT:
        return "Disconnect";
    case GOEP_OPER_ABORT:
        return "Abort";
	case GOEP_OPER_DELETE:
        return "Delete";
	case GOEP_OPER_SETFOLDER:
        return "Set Folder";
    }
    return "Unknown";
}


/*---------------------------------------------------------------------------
 * mfw_btips_oppcBuildPushObject()
 *
 * Synopsis:  Build push object
 *
 * Return:    TRUE - success FALSE - failed
 *
 */
static BOOL mfw_btips_oppcBuildPushObject(BtlObject *objToPush, const char *fsPath, char *buff)
{
	if (oppClient.objLocation == BTL_OBJECT_LOCATION_MEM)
	{
		if (TRUE != mfw_btips_oppcConvertToMemPushObject(objToPush, fsPath, buff))
        {
           return FALSE;
        }
	}
    else if (oppClient.objLocation == BTL_OBJECT_LOCATION_FS)
    {
        mfw_btips_oppcSetFsPushObject(objToPush, fsPath);
    }

    return TRUE;
}


/*---------------------------------------------------------------------------
 * mfw_btips_oppcBuildPullObject()
 *
 * Synopsis:  Build push object
 *
 * Return:    TRUE - success FALSE - failed
 *
 */
static BOOL mfw_btips_oppcBuildPullObject(BtlObject *objToPull, const char *fsPath, char *buff)
{
	if (oppClient.objLocation == BTL_OBJECT_LOCATION_MEM)
	{
		mfw_btips_oppcSetMemPullObject(objToPull, fsPath, buff);
	}
    else if (oppClient.objLocation == BTL_OBJECT_LOCATION_FS)
    {
        mfw_btips_oppcSetFsPullObject(objToPull, fsPath);	
    }

    return TRUE;
}


/*---------------------------------------------------------------------------
 * mfw_btips_oppcConvertToMemPushObject()
 *
 * Synopsis:  Function for testing OPP from memory objects. Convert file object to memory object by reading the 
 *            file and modifying proper fileds uses a static buffer, so only one such object can be supported at a time
 *            maximum file size is 512 KB
 *
 * Return:    void
 *
 */
static BOOL mfw_btips_oppcConvertToMemPushObject(BtlObject *obj, const char *fsPushPath, char *buff)
{
	BtFsStatus btFsStatus;
    BthalFsFileDesc fd;
	BTHAL_U32 numRead;
    BthalFsStat FileStat;

   	btFsStatus = BTHAL_FS_Stat((const BTHAL_U8 *)fsPushPath, &FileStat); 
	if(btFsStatus != BT_STATUS_HAL_FS_SUCCESS)
	{
		Report(("Client: Error - File was not found %s", fsPushPath));
        return FALSE;
	}
	
    if (FileStat.size > OPPCA_BUFF_MAX)
    {
        Report(("Client: Error pushed file > %d bytes", OPPCA_BUFF_MAX));
        return FALSE;
    }
       
    btFsStatus = BTHAL_FS_Open((const BTHAL_U8 *)fsPushPath, 
		            BTHAL_FS_O_RDONLY | BTHAL_FS_O_BINARY,      /* Read Only */
                            (BthalFsFileDesc *)&fd);
 
    if (btFsStatus == BT_STATUS_HAL_FS_SUCCESS)
	{
        btFsStatus  = BTHAL_FS_Read(fd, oppClient.pushBuff, OPPCA_BUFF_MAX, &numRead);
        
        if (btFsStatus == BT_STATUS_HAL_FS_SUCCESS)
	 	{
			Report(("Client: fsPushPath = %s, numRead = %d", fsPushPath, numRead));
	 	}
		
        BTHAL_FS_Close(fd);
	
        /* Extract object name from fsPath */
        OBSTORE_ExtractObjName(fsPushPath, ObPushName);
        
        obj->objectLocation                 = BTL_OBJECT_LOCATION_MEM;
		obj->objectName                     = ObPushName;
        obj->location.memLocation.memAddr   = buff;
		obj->location.memLocation.size      = numRead;
        obj->objectMimeType 			    = "text/x-vCard";
    }
    else
    {
    	Report(("Client: Error - could not open %s", fsPushPath));
        return FALSE;
    }

    return TRUE;
}


/*---------------------------------------------------------------------------
 * mfw_btips_oppcSetMemPullObject()
 *
 * Synopsis:  Function for testing OPP from memory objects. 
 *            Sets memory object fields prior to PULL operation
 *
 * Return:    void
 *
 */
static void mfw_btips_oppcSetMemPullObject(BtlObject *obj, const char *fsPullPath, char *buff)
{			
	OBSTORE_ExtractObjName(fsPullPath, ObPullName);
    
    obj->objectLocation                 = BTL_OBJECT_LOCATION_MEM;
	
    obj->location.fsLocation.fsPath     = NULL;
	obj->location.memLocation.memAddr   = buff;
	obj->location.memLocation.size      = OPPCA_BUFF_MAX;		

    obj->objectMimeType 		        = "text/x-vCard";;
    obj->objectName                     = ObPullName;
}


/*---------------------------------------------------------------------------
 * mfw_btips_oppcSetFsPushObject()
 *
 * Synopsis:  Function for testing OPP from FS Push objects. 
  *
 * Return:    void
 *
 */
static void mfw_btips_oppcSetFsPushObject(BtlObject *obj, const char *fsPushPath)
{			
    OBSTORE_ExtractObjName(fsPushPath, ObPushName);

    obj->objectName      			    = ObPushName;
	obj->location.fsLocation.fsPath     = fsPushPath;
	
    /* This should be provided by the user (i.e. this is just an example) */
    obj->objectMimeType 			    = "text/x-vCard";
	obj->objectLocation 			    = BTL_OBJECT_LOCATION_FS;
}


/*---------------------------------------------------------------------------
 * mfw_btips_oppcSetFsPullObject()
 *
 * Synopsis:  Function for testing OPP from FS Pull objects. 
  *
 * Return:    void
 *
 */
static void mfw_btips_oppcSetFsPullObject(BtlObject *obj, const char *fsPullPath)
{			
    OBSTORE_ExtractObjName(fsPullPath, ObPullName);

    obj->objectName      			    = ObPullName;
	obj->location.fsLocation.fsPath     = fsPullPath;
	obj->objectMimeType 			    = "text/x-vCard";
	obj->objectLocation 			    = BTL_OBJECT_LOCATION_FS;
}

/*---------------------------------------------------------------------------
 *            mfw_btips_oppcCallback
 *---------------------------------------------------------------------------
 *
 * Synopsis:  This function processes OBEX client protocol events.
 *
 * Return:    void
 *
 */
void mfw_btips_oppcCallback(T_BTIPS_MMI_IND *para)
{

}

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

 $Function:     mfw_btips_oppcPopulateFiles

 $Description:Populates file names into the array

 $Returns:		The count of the files in the directory

 $Arguments:		file_names:Pointer to the arrayto store file names
				max_files_count:Max file counts to be stored in array
*******************************************************************************/
int mfw_btips_oppcPopulateFiles(char **file_names, int max_files_count,char* dir_name_p)
{

	T_FFS_DIR	dir                             = {0};
	char		       dest_name_p[100]    =  "";
	int                  i, files_count            =  0;
	char               *fileExt;

	TRACE_FUNCTION_P1("mfw_btips_oppcPopulateFiles from directory %s", dir_name_p);

	if (ffs_opendir (dir_name_p, &dir) <= 0)
	{
	       TRACE_ERROR("Could not open Dir");
		
		files_count = 0;
	}
	//Release previous allocated memory before allocating again
	mfw_btips_oppcUnpopulateFiles(file_names);
	//read the  file names
	//file_count will be used to populate the array index
	for (i = 0; ffs_readdir (&dir, dest_name_p, 100) > 0x0; i++)
	{
		if((strcmp(dest_name_p, ".") == 0) || (strcmp(dest_name_p, "..") == 0))
			continue;
		TRACE_FUNCTION_P1("Reading Dir - %s",dest_name_p);
		(file_names[files_count]) = (char*)mfwAlloc(strlen(dest_name_p) + 1);
		if(file_names[files_count] != NULL)
		{
			#if 0
			//Retrieve file extension.Store only the supported file formats in array
			fileExt =mfw_btips_oppcGetExtension(dest_name_p);
			//List the MP3 files also.Mp3 files hsould not be listed or ULC
			if ( (strcmp(fileExt, "mp3") == 0))
			{
				strcpy (file_names[files_count], dest_name_p);
				files_count++;
			}
			else if ( (strcmp(fileExt, "wav")== 0))
			{
				strcpy (file_names[files_count], dest_name_p);
				files_count++;
			}
			else if ( (strcmp(fileExt, "pcm")== 0))
			{
				strcpy (file_names[files_count], dest_name_p);
				files_count++;
			}
			else if(files_count >= max_files_count)
				break;
			#endif
			strcpy (file_names[files_count], dest_name_p);
			TRACE_FUNCTION_P1("file_names - %s", file_names[files_count]);
			files_count++;
			if(files_count >= max_files_count)
				break;
		}		
		else
		{
			//files_count = 0;
		}		

	}
	//Closing the directory aa per the new FFS logic
	ffs_closedir(dir);
 
	TRACE_EVENT_P1("read  files_count is %d",files_count);
	TRACE_FUNCTION_P1("read  files_count is %d",files_count);
	return files_count;
}
/*******************************************************************************

 $Function:     mfw_btips_oppcUnpopulateFiles

 $Description:Frees the memory allocated for the array
 $Returns:		None

 $Arguments:		file_names:Pointer to the arrayto store file names

*******************************************************************************/
void mfw_btips_oppcUnpopulateFiles(char **file_names)
{
	int i;
	TRACE_FUNCTION("mfw_btips_oppcUnpopulateFiles");
	mfw_BtipsReport("mfw_btips_oppcUnpopulateFiles");
	
	//Free the allocated memory for file names
	for (i = 0; i<OPPC_MAX_FILES; i++)
	{
		if(file_names[i])
		{
	           mfwFree((U8 *)file_names[i],(U16)strlen(file_names[i]) + 1);
		}
		file_names[i]=NULL;
	}
    
}

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

 $Function:     mfw_btips_oppcGetExtension

 $Description: public function to retrieve the extension of a file

 $Returns:Extention of the filename

 $Arguments: scr- Filename

*******************************************************************************/
 char *mfw_btips_oppcGetExtension(char *src)
{
    int i,len;

	TRACE_FUNCTION("mfw_btips_oppcGetExtension");
		mfw_BtipsReport("mfw_btips_oppcGetExtension");
    len = strlen(src);  
    for(i = 0; i < len; i++){
        if(src[i] == '.'){
            return (src+i+1);
        }
    }
    return (src+i);
}
/*******************************************************************************

 $Function:     mfw_btips_oppcGetNumFiles

 $Description: returns the file count 

 $Returns:		Count of the Midi files

 $Arguments:		None

*******************************************************************************/
int mfw_btips_oppcGetNumFiles(void)
{
	TRACE_FUNCTION_P1("mfw_btips_oppcGetNumFiles -oppc_files_count - %d", oppc_files_count);	
	if(oppc_files_count<=0)
		return 0;
	else
		return oppc_files_count; 

}
/*******************************************************************************

 $Function:     mfw_btips_oppcGetFileName

 $Description: Returns the file name 

 $Returns:		Name of the file 

 $Arguments:		index:The index of the file, whose name has to be retrieved

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

char* mfw_btips_oppcGetFileName(UBYTE index)
{

	TRACE_FUNCTION_P2("oppc_file_names[%d] is %s",index,(char *)oppc_file_names[index]);
	return (char *) oppc_file_names[index];
}
/*******************************************************************************

 $Function:     mfw_btips_oppcGetConnectDevice

 $Description: Returns the TRUE when succeeds
 $Returns:		TRUE or FALSE 

 $Arguments:		

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

BOOL mfw_btips_oppcGetConnectedDevice (BD_ADDR *bdAddr, U8 *name)
{
	BtStatus status;
	char bdaddrstring[BDADDR_NTOA_SIZE];
	
	status = BTL_OPPC_GetConnectedDevice (oppcContext, bdAddr);
	bdaddr_ntoa(bdAddr,bdaddrstring);
	TRACE_FUNCTION_P1("mfw_btips_ftpsGetConnectDevice OPPC %s  ",bdaddrstring);
	
	if (status == BT_STATUS_SUCCESS)
	{
		mfw_btips_bmgGetDeviceName (bdAddr, name);
		TRACE_FUNCTION_P1("mfw_btips_oppcGetConnectDevice OPPC name %s  ",name);
		return TRUE;
	}
	return FALSE;
}

void mfw_btips_oppc_Disconnect(void)
{
	BtStatus status; 	

    if (oppClient.isConnected == TRUE)
	{
        status = BTL_OPPC_Disconnect(oppcContext);
		Report(("BTL_OPPC_Disconnect() returned %s.", pBT_Status(status)));
	}
	else
	{
		Report(("mfw_btips_oppc_Disconnect: Client is not connected!"));
	}
}


#endif