FreeCalypso > hg > fc-magnetite
view src/aci2/mfw/mfw_bte.c @ 385:ae81cbcffabb
doc/C139-Howto deleted, superceded by the new C1xx-Howto
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 14 Jan 2018 21:03:04 +0000 |
parents | 93999a60b835 |
children |
line wrap: on
line source
/* +-------------------------------------------------------------------+ | PROJECT: MMI-Framework (8445) $Workfile:: mfw_bt.c $| | $Author:: NDH $Revision:: 1 $| | CREATED: 17.04.04 $Modtime:: 17.04.04 17:21 $| | STATE : code | +-------------------------------------------------------------------+ MODULE : MFW_BT PURPOSE : This module contains the functions for MFW Bluetooth Management */ #define ENTITY_MFW #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 #include "bta_riviera.h" #include "bta_api.h" #include "mfw_bt_geh.h" #include "mfw_bte.h" #include "mfw_bt_dm.h" #include "mfw_bt_dg.h" #include "mfw_bt_ag.h" #include "mfw_bt_op.h" #include "mfw_bt_ft.h" #include "mfw_bt_flash.h" #include "mfw_utils.h" /* ** Define Module wide variables */ static SHORT Mfw_Bt_Ge_Sigbuf_Id = -1; static BOOLEAN Mfw_Bt_Ge_InProgress; static T_MFW_STARTUP_VISIBILITY startup_visibility; /* ** Local Function Prototypes */ static void mfw_bt_send_cb_notify_ind (void); /* ** Define External variables and references */ EXTERN MfwHdr * current_mfw_elem; /* ** Module Function Definitoins */ /******************************************************************************* $Function: mfw_bt_enable $Description: This function will start the whole process of enabling Bluetooth. $Returns: MFW_BT_FAIL if the chip is not stopped or if the generic event handler doesn't start correctly. $Arguments: startup_visibility. Visibility set by the BMI. MFW_BT_DEFAULT_VIS if using the settings stored in flash. *******************************************************************************/ T_MFW_BT_STATUS mfw_bt_enable(T_MFW_STARTUP_VISIBILITY startup_visibility ) { UINT8 delay_counter = 0; T_RV_RET bt_start_status = 0; T_MFW_BT_STATUS status; // static tBTA_SYS_START_CBACK *fp; // fp= (tBTA_SYS_START_CBACK *)&mfw_bt_dm_security_cb; /* first, enable the event handler */ status = mfw_bt_ge_enable(); if( status != MFW_BT_SUCCESS ) return status; /* start the system */ if( BTA_SysStart((tBTA_SYS_START_CBACK *)(&mfw_bt_dm_security_cb) ) != RV_OK ) // if( BTA_SysStart(fp) != RV_OK ) { MFW_BT_TRACE( "[mfw_bt]: failed to start BT chipset" ); return MFW_BT_FAIL; } /* the start-up procedure has been started. We will receive an event when it is done */ MFW_BT_TRACE( "[mfw_bt]: BT is starting" ); return MFW_BT_SUCCESS; } /* */ /******************************************************************************* $Function: mfw_bt_enable_cb $Description: mfw_bt_enable will cause a BTA_DM_SYS_START_EVT to be sent. At this moment we call BTA_EnableBluetooth. When we receive BTA_DM_ENABLE_EVT, we call this function. $Returns: Will send a BMI signal if there is no default name. If the user cancels the input, BT will then be stopped. Will send a E_BT_ENABLE_CMPL event when the initialization is done. $Arguments: none *******************************************************************************/ void mfw_bt_enable_cb(void) { UINT8* device_name; T_MFW_BT_REM_DEVICE *ptr_device_array[MFW_BT_NUM_REM_DEVICE]; UINT8 number_of_devices; T_MFW_BT_ENABLE_CMPL enable_evt_data; mfw_bt_cb.is_started = TRUE; /* set device name */ device_name = mfw_bt_read_local_name( ); if( *device_name == NULL ) { /* no name yet. Use default one, and ask the user to specify a new one */ BTA_DmSetDeviceName((char*)MFW_BT_DEVICE_NAME); mfw_bt_cb.is_name_requested = TRUE; mfw_bt_signal(E_BT_DM_DEV_NAME_REQ, NULL); } else BTA_DmSetDeviceName( (char*)device_name ); /* set visibility and connectability */ if( startup_visibility == MFW_BT_DEFAULT_VIS ) { if( mfw_bt_read_visibility( ) == TRUE ) { BTA_DmSetVisibility( BTA_DM_GENERAL_DISC, BTA_DM_CONN); } else { BTA_DmSetVisibility( BTA_DM_NON_DISC, BTA_DM_NON_CONN); } } else { BTA_DmSetVisibility( startup_visibility, BTA_DM_NON_CONN); } /* Update BTA with peer device information stored in NVRAM */ /* first, get all the devices */ mfw_bt_get_device_by_service(0, &ptr_device_array[0], &number_of_devices); /* then add these devices to BTA database. */ for ( ; number_of_devices>0 ; number_of_devices-- ) { if(ptr_device_array[number_of_devices]->link_key_present) { BTA_DmAddDevice(ptr_device_array[number_of_devices]->bd_addr, ptr_device_array[number_of_devices]->link_key, ptr_device_array[number_of_devices]->trusted_services, ptr_device_array[number_of_devices]->is_trusted); } else if (ptr_device_array[number_of_devices]->is_trusted) { BTA_DmAddDevice(ptr_device_array[number_of_devices]->bd_addr, NULL, ptr_device_array[number_of_devices]->trusted_services, ptr_device_array[number_of_devices]->is_trusted); } } /* initialize all the sub-parts => BT profiles. THIS CODE IS ABSOLUTELY NOT DYNAMIC... Does it need to be??? */ mfw_bt_ag_init(); mfw_bt_dg_init(); mfw_bt_op_init(); mfw_bt_ft_init(); /* finally platform-specific initialization */ //nothing to do for the time being. /* store the new settings. this stores base conf file */ mfw_bt_store_status(TRUE); enable_evt_data.Success = TRUE; mfw_bt_signal(E_BT_ENABLE_CMPL, (void*)&enable_evt_data ); return; } /******************************************************************************* $Function: mfw_bt_disable $Description: This function stops the BT system. $Returns: None $Arguments: None *******************************************************************************/ void mfw_bt_disable(void) { /* disable BT. DM handler will then receive an DISABLE event => will stop the chipset and kill the generic event handler. */ BTA_DisableBluetooth( ); return; } /******************************************************************************* $Function: mfw_bt_init $Description: This function initialises the Mfw Bluetooth Persistent Data on Power Up. $Returns: None $Arguments: None *******************************************************************************/ void mfw_bt_init(void) { /* ** Read the Known Devices from FFS */ mfw_bt_flash_init( ); /* ** The rest is down to you Thomas */ return; } /******************************************************************************* $Function: mfw_bt_exit $Description: This function will tidy up any resources used by the Mfw Bluetooth Module on Power Down $Returns: None $Arguments: None *******************************************************************************/ void mfw_bt_exit(void) { /* nothing to do here... RAM will be automatically cleaned, and the flash wasn't modified */ return; } /******************************************************************************* $Function: mfw_bt_create $Description: This function initialises an Mfw Bluetooth entity and adds it to the Window Stack $Returns: T_MFW_HND : A handle for the entity $Arguments: T_MFW_HND : Parent Window Handle T_MFW_EVENT : Event Mask of the events to be handled T_MFW_CB : Callback function to handle the events *******************************************************************************/ T_MFW_HND mfw_bt_create(T_MFW_HND hWin, T_MFW_EVENT event, T_MFW_CB cbfunc) { T_MFW_HDR *hdr; T_MFW_BT *bt_para; MFW_BT_TRACE("mfw_bt_create"); hdr = (T_MFW_HDR *) mfwAlloc(sizeof (T_MFW_HDR)); bt_para = (T_MFW_BT *) mfwAlloc(sizeof (T_MFW_BT)); if (!hdr OR !bt_para) return FALSE; /* * initialisation of the handler */ bt_para->emask = event; bt_para->handler = cbfunc; hdr->data = bt_para; /* store parameter in node */ hdr->type = MfwTypBt; /* store type of event handler */ /* * installation of the handler */ return mfwInsert((T_MFW_HDR *)hWin, hdr); } /******************************************************************************* $Function: mfw_bt_delete $Description: This function clears down an Mfw Bluetooth entity and removes it from the Window Stack $Returns: T_MFW_RES : The result of the function $Arguments: T_MFW_HND : The Handle of the entity to be removed *******************************************************************************/ T_MFW_RES mfw_bt_delete(T_MFW_HND hnd) { MFW_BT_TRACE("mfw_bt_delete"); if (!hnd OR !((T_MFW_HDR *)hnd)->data) return MFW_RES_ILL_HND; if (!mfwRemove((T_MFW_HDR *)hnd)) return MFW_RES_ILL_HND; mfwFree((U8 *)(((T_MFW_HDR *) hnd)->data),sizeof(T_MFW_BT)); mfwFree((U8 *)hnd,sizeof(T_MFW_HDR)); return MFW_RES_OK; } /******************************************************************************* $Function: mfw_bt_signal $Description: This function sends the Mfw Bluetooth events from the Mfw to the BMI. $Returns: None $Arguments: T_MFW_EVENT : The event to be sent to the BMI void * : Pointer to the Event data *******************************************************************************/ void mfw_bt_signal(T_MFW_EVENT event, void *para) { UBYTE temp; temp = dspl_Enable(0); if (mfwSignallingMethod EQ 0) { /* * focus is on a window */ if (mfwFocus) { /* * send event to sim management * handler if available */ if (mfw_bt_sign_exec (mfwFocus, event, para)) { dspl_Enable(temp); return; } } /* * actual focussed window is not available * or has no network management registration * handler, then search all nodes from the root. */ if (mfwRoot) mfw_bt_sign_exec (mfwRoot, event, para); } else { MfwHdr * h = 0; /* * Focus set, then start here */ if (mfwFocus) h = mfwFocus; /* * Focus not set, then start root */ if (!h) h = mfwRoot; /* * No elements available, return */ while (h) { /* * Signal consumed, then return */ if (mfw_bt_sign_exec (h, event, para)) { dspl_Enable(temp); return; } /* * All windows tried inclusive root */ if (h == mfwRoot) { dspl_Enable(temp); return; } /* * get parent window */ h = mfwParent(mfwParent(h)); if (h) h = ((MfwWin * )(h->data))->elems; } mfw_bt_sign_exec (mfwRoot, event, para); } dspl_Enable(temp); return; } /******************************************************************************* $Function: mfw_bt_sign_exec $Description: This function sends the Mfw Bluetooth events from the Mfw to the BMI. $Returns: None $Arguments: None *******************************************************************************/ BOOL mfw_bt_sign_exec (T_MFW_HDR * cur_elem, T_MFW_EVENT event, T_MFW_BT_PARA * para) { MFW_BT_TRACE("mfw_bt_sign_exec"); while (cur_elem) { /* * event handler is available */ if (cur_elem->type EQ MfwTypBt) { T_MFW_BT * bt_data; /* * handler is CM management handler */ bt_data = (T_MFW_BT *)cur_elem->data; if (bt_data->emask & event) { /* * event is expected by the call back function */ bt_data->event = event; switch (event) { /* ** Generic Events */ case E_BT_ENABLE_CMPL: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_ENABLE_CMPL)); break; case E_BT_DISABLE_CMPL: memset(&bt_data->para, 0x00, sizeof(T_MFW_BT_PARA)); break; /* ** Device Manager Events */ case E_BT_DM_LINK_UP: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_LINK_UP)); break; case E_BT_DM_LINK_DOWN: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_LINK_DOWN)); break; case E_BT_DM_INQ_RES: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_INQ_RES)); break; case E_BT_DM_INQ_CMPL: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_INQ_CMPL)); break; case E_BT_DM_DISC_RES: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_DISC_RES)); break; case E_BT_DM_DISC_CMPL: memset(&bt_data->para, 0x00, sizeof(T_MFW_BT_PARA)); break; case E_BT_DM_PIN_REQ: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_PIN_REQ)); break; case E_BT_DM_AUTH_CMPL: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_AUTH_CMPL)); break; case E_BT_DM_AUTHORIZE_REQ: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_AUTHORIZE_REQ)); break; case E_BT_DM_DEV_NAME_REQ: memset(&bt_data->para, 0x00, sizeof(T_MFW_BT_PARA)); break; case E_BT_DM_SIG_STRENGTH_IND: memcpy (&bt_data->para, para, sizeof (T_MFW_BT_DM_SIG_STRENGTH_IND)); break; } /* * if call back defined, call it */ if (bt_data->handler) { // store current mfw elem current_mfw_elem = cur_elem; if ((*(bt_data->handler)) (bt_data->event, (void *)&bt_data->para)) return TRUE; } } } cur_elem = cur_elem->next; } return FALSE; } /******************************************************************************* $Function: mfw_bt_ge_enable $Description: This function initialises the Generic Event Handler, it should be active only when bluetooth is enabled. $Returns: MFW_BT_UNABLE_TO_CREATE_EVT_BUF : Failed to start - memory problems MFW_BT_SUCCESS : Started OK, and Ready $Arguments: None *******************************************************************************/ T_MFW_BT_STATUS mfw_bt_ge_enable (void) { SHORT cbufRetVal; MFW_BT_TRACE("mfw_bt_ge_enable"); /* ** Try to create the Circular Event Buffer */ cbufRetVal = mfw_cbuf_create(MFW_BT_MAX_SIG_Q_ENTRIES, /* Max Entires */ sizeof(T_MFW_BT_SIGNALS), /* Item Size */ FALSE, /* Don't Overwrite */ 0xFF, /* Null Character */ FALSE, /* Dynamic Buffer */ (void *)0); /* Buffer pointer not required */ if (cbufRetVal == MFW_CBUF_MEM_ALLOC_FAILURE) { MFW_BT_TRACE("mfw_bt_ge_enable > Buffer Creation Failed with Mem Constraints"); /* ** Failed due to memory constraints, try again with half the number of entries */ cbufRetVal = mfw_cbuf_create(MFW_BT_MAX_SIG_Q_ENTRIES/2, /* Max Entires */ sizeof(T_MFW_BT_SIGNALS), /* Item Size */ FALSE, /* Don't Overwrite */ 0xFF, /* Null Character */ FALSE, /* Dynamic Buffer */ (void *)0); /* Buffer pointer not required */ /* ** All MFW_CBUF error codes are negative, 0 or a positive value from mfw_cbuf_create is a valid buffer Id */ if (cbufRetVal < 0) { MFW_BT_TRACE_P1("mfw_bt_ge_enable > Unable to Create Buffer : Error %d", cbufRetVal); /* ** Failed to allocate buffer, return an error */ return MFW_BT_UNABLE_TO_CREATE_EVT_BUF; } } else if (cbufRetVal < 0) { MFW_BT_TRACE_P1("mfw_bt_ge_enable > Unable to Create Buffer : Error %d", cbufRetVal); /* ** Failed to allocate buffer, return an error */ return MFW_BT_UNABLE_TO_CREATE_EVT_BUF; } MFW_BT_TRACE_P1("mfw_bt_ge_enable > Buffer created successfully with Id %d", cbufRetVal); /* ** A buffer has been created, store the Id for future use. */ Mfw_Bt_Ge_Sigbuf_Id = cbufRetVal; return MFW_BT_SUCCESS; } /******************************************************************************* $Function: mfw_bt_ge_disable $Description: Disbales the Generic Event Handler, and releases the Dynamic Event Buffer $Returns: None $Arguments: None *******************************************************************************/ void mfw_bt_ge_disable (void) { MFW_BT_TRACE("mfw_bt_ge_disable"); /* ** Ensure the MFW Bluetooth Event handler is initialised */ if (Mfw_Bt_Ge_Sigbuf_Id < 0) { MFW_BT_TRACE("mfw_bt_ge_disable > Bluetooth Module Not Initialised"); } else { mfw_cbuf_delete(Mfw_Bt_Ge_Sigbuf_Id); Mfw_Bt_Ge_Sigbuf_Id = -1; } } /******************************************************************************* $Function: mfw_bt_ge_post_event $Description: This function stores the incoming event in the event buffer, and if required, notifies the MMI Task $Returns: MFW_BT_NOT_INITIALISED : Fn mfw_bt_ge_enable not called or failed MFW_BT_INVALID_ORIG : Invalid Originator Id received MFW_BT_INVALID_EVENT : Invalid Event Id received MFW_BT_INVALID_DATA : Mismatch between the data pointer and datalen values MFW_BT_FAILED_TO_STORE_EVENT : Event Buffer Full (check trace) MFW_BT_SUCCESS : Event Stored successfuly $Arguments: originator : Identifier for the originating profile that caused the event eventId : Event Identifier (See BTA Specification) data : pointer to the event data dataLen : length of the event data in bytes (must be 0 if data is (void *)0) *******************************************************************************/ T_MFW_BT_STATUS mfw_bt_ge_post_event (T_MFW_BT_ORIGINATORS originator, ULONG eventId, void * data, int dataLen) { T_MFW_BT_SIGNALS sigBuffer; USHORT numElements; SHORT cbufRetVal; MFW_BT_TRACE("mfw_bt_ge_post_event"); /* ** Ensure the MFW Bluetooth Event handler is initialised */ if (Mfw_Bt_Ge_Sigbuf_Id < 0) { MFW_BT_TRACE("mfw_bt_ge_post_event > Bluetooth Module Not Initialised"); return MFW_BT_NOT_INITIALISED; } /* ** Validate the incoming Parameters */ if ((originator >= MFW_BT_MAX_ORIGINATOR) || ((originator & (ULONG)0xFFFF) != 0)) { MFW_BT_TRACE_P1("mfw_bt_ge_post_event > Originator Invalid : 0x%lx", originator); return MFW_BT_INVALID_ORIG; } if (eventId > (ULONG)0xFFFF) { MFW_BT_TRACE_P1("mfw_bt_ge_post_event > Event Id Invalid : 0x%lx", eventId); return MFW_BT_INVALID_EVENT; } if ((dataLen < 0) || ((data == (void *)0) && (dataLen != 0)) || ((data != (void *)0) && (dataLen == 0))) { MFW_BT_TRACE_P2("mfw_bt_ge_post_event > Data, DataLen combination Invalid : data 0x%lx, dataLen %d", data, dataLen); return MFW_BT_INVALID_DATA; } /* ** Create the Event for storage, which is combined from the OriginatorId and the EventId */ sigBuffer.event = originator | eventId; /* ** Copy the Signal Data for storage */ memcpy((void *)&sigBuffer.data, data, dataLen); /* ** Get the existing number of elements in the Event Buffer */ numElements = mfw_cbuf_num_elements (Mfw_Bt_Ge_Sigbuf_Id); /* ** Post the event to the buffer */ cbufRetVal = mfw_cbuf_put(Mfw_Bt_Ge_Sigbuf_Id, (void *)&sigBuffer); if (cbufRetVal != MFW_CBUF_OK) { /* ** Unable to store the data */ MFW_BT_TRACE_P1("mfw_bt_ge_post_event > Unable to store the event : Error %d", cbufRetVal); return MFW_BT_FAILED_TO_STORE_EVENT; } MFW_BT_TRACE("mfw_bt_ge_post_event > Event Successfully Stored"); /* ** If required, Post the MMI_BT_CB_NOTIFY_RXD_IND Primitive */ if ((numElements == 0) && (Mfw_Bt_Ge_InProgress == FALSE)) { /* ** Sending Primitive to MMI TASK */ MFW_BT_TRACE("mfw_bt_ge_post_event > Sending Primitive to MMI TASK"); mfw_bt_send_cb_notify_ind(); } #ifdef MFW_BT_DEBUG else { /* ** Sending Primitive to MMI TASK */ MFW_BT_TRACE("mfw_bt_ge_post_event > No need to send Primitive to MMI TASK"); } #endif return MFW_BT_SUCCESS; } /******************************************************************************* $Function: mfw_bt_cb_notify_rxd $Description: This function is called on receipt of the MMI_BT_CB_NOTIFY_IND primitive, it reads the events from the event buffer and passes the details to the appropriate Profile Handler. It will process a Maximum of MFW_BT_MAX_CONSEC_SIG_PROC events before reposting the primitive to the MMI Queue and relinquishing control. $Returns: None $Arguments: None *******************************************************************************/ void mfw_bt_cb_notify_rxd(void) { T_MFW_BT_SIGNALS sigBuffer; T_MFW_BT_ORIGINATORS originatorId; T_MFW_BT_STATUS hndlrRetVal; ULONG eventId; UBYTE numSigsProcessed; SHORT cbufRetVal; MFW_BT_TRACE("mfw_bt_cb_notify_rxd"); if (Mfw_Bt_Ge_Sigbuf_Id < 0) { MFW_BT_TRACE("Mfw_Bt_cb_notify_rxd > Bluetooth Module Not Initialised"); return; } /* ** Initialise Local and Module variables as required. */ Mfw_Bt_Ge_InProgress = TRUE; numSigsProcessed = 0; /* ** While there are events in the Buffer, and the maximum number of signals have not ** been processed ... */ while ((numSigsProcessed < MFW_BT_MAX_CONSEC_SIG_PROC) && (mfw_cbuf_num_elements(Mfw_Bt_Ge_Sigbuf_Id) > 0)) { numSigsProcessed++; /* ** Read the event details from the buffer */ cbufRetVal = mfw_cbuf_get(Mfw_Bt_Ge_Sigbuf_Id, (void *)&sigBuffer); if (cbufRetVal != MFW_CBUF_OK) { Mfw_Bt_Ge_InProgress = FALSE; (void)mfw_cbuf_reset(Mfw_Bt_Ge_Sigbuf_Id); MFW_BT_TRACE_P1("Mfw_Bt_cb_notify_rxd > Unable to read events from Buffer : Error %d", cbufRetVal); return; } /* ** Seperate the Originator and Event Id values */ originatorId = sigBuffer.event & (ULONG)0xFFFF0000; eventId = sigBuffer.event & (ULONG)0x0000FFFF; /* ** switch on the originator Id */ switch (originatorId) { case MFW_BT_DM_SECURITY: hndlrRetVal = mfw_bt_dm_security_hndlr((T_MFW_BT_DM_SEC_EVT)eventId, (T_MFW_BT_DM_SEC_SIG_DATA *)&sigBuffer.data.dmSecSignals); break; case MFW_BT_DM_SEARCH: hndlrRetVal = mfw_bt_dm_search_hndlr((T_MFW_BT_DM_SRCH_EVT)eventId, (T_MFW_BT_DM_SRCH_SIG_DATA *)&sigBuffer.data.dmSrchSignals); break; case MFW_BT_DG: hndlrRetVal = mfw_bt_dg_hndlr((T_MFW_BT_DG_EVT)eventId, (T_MFW_BT_DG_SIG_DATA *)&sigBuffer.data.dgSignals); break; case MFW_BT_AG: hndlrRetVal = mfw_bt_ag_hndlr((T_MFW_BT_AG_EVT)eventId, (T_MFW_BT_AG_SIG_DATA *)&sigBuffer.data.agSignals); break; case MFW_BT_OPC: hndlrRetVal = mfw_bt_opc_hndlr((T_MFW_BT_OPC_EVT)eventId, (T_MFW_BT_OPC_SIG_DATA *)&sigBuffer.data.opcSignals); break; case MFW_BT_OPS: hndlrRetVal = mfw_bt_ops_hndlr((T_MFW_BT_OPS_EVT)eventId, (T_MFW_BT_OPS_SIG_DATA *)&sigBuffer.data.opsSignals); break; case MFW_BT_FTC: hndlrRetVal = mfw_bt_ftc_hndlr((T_MFW_BT_FTC_EVT)eventId, (T_MFW_BT_FTC_SIG_DATA *)&sigBuffer.data.ftcSignals); break; case MFW_BT_FTS: hndlrRetVal = mfw_bt_fts_hndlr((T_MFW_BT_FTS_EVT)eventId, (T_MFW_BT_FTS_SIG_DATA *)&sigBuffer.data.ftsSignals); break; default: MFW_BT_TRACE_P1("mfw_bt_cb_notify_rxd > Invalid Originator 0x%lx", originatorId); hndlrRetVal = MFW_BT_SUCCESS; /* Set the return value to success because an error has already been reported */ } if (hndlrRetVal <= 0) { /* Error reported by the handler, not a lot can be done, expect report it */ MFW_BT_TRACE_P2("mfw_bt_cb_notify_rxd > Error %d returned from Event handler for Originator 0x%lx", hndlrRetVal, originatorId); } } Mfw_Bt_Ge_InProgress = FALSE; /* ** If there are still signals in the buffer, send another MMI_BT_CB_NOTIFY_RXD_IND primitive */ if (mfw_cbuf_num_elements(Mfw_Bt_Ge_Sigbuf_Id) > 0) { MFW_BT_TRACE("Mfw_Bt_cb_notify_rxd > Send the MMI_BT_CB_NOTIFY_IND signal"); mfw_bt_send_cb_notify_ind(); } return; } /************************************************************************************************** ** ** Local Function Definitions ** **************************************************************************************************/ #define hCommACI _ENTITY_PREFIXED(hCommACI) /******************************************************************************* $Function: mfw_bt_send_cb_notify_ind $Description: This function posts the MMI_BT_CB_NOTIFY_IND primitive to the MMI Queue $Returns: None $Arguments: None *******************************************************************************/ static void mfw_bt_send_cb_notify_ind (void) { #if defined (NEW_FRAME) EXTERN T_HANDLE hCommACI; ULONG signal_raw; #else EXTERN T_VSI_CHANDLE hCommACI; #endif PALLOC(bt_cb_notify_ind,MMI_BT_CB_NOTIFY_IND); MFW_BT_TRACE("mfw_bt_send_cb_notify_ind"); #if defined (NEW_FRAME) PSENDX(ACI,bt_cb_notify_ind); #else #if defined (_TMS470) vsi_c_send("",hCommACI,D2P(bt_cb_notify_ind), sizeof(T_PRIM_HEADER)+sizeof(T_MMI_BT_CB_NOTIFY_IND)); #else PSEND(ACI,bt_cb_notify_ind); #endif #endif return; }