FreeCalypso > hg > fc-tourmaline
view src/ui/bmi/mmiSmsSend.h @ 220:0ed36de51973
ABB semaphore protection overhaul
The ABB semaphone protection logic that came with TCS211 from TI
was broken in several ways:
* Some semaphore-protected functions were called from Application_Initialize()
context. NU_Obtain_Semaphore() called with NU_SUSPEND fails with
NU_INVALID_SUSPEND in this context, but the return value wasn't checked,
and NU_Release_Semaphore() would be called unconditionally at the end.
The latter call would increment the semaphore count past 1, making the
semaphore no longer binary and thus no longer effective for resource
protection. The fix is to check the return value from NU_Obtain_Semaphore()
and skip the NU_Release_Semaphore() call if the semaphore wasn't properly
obtained.
* Some SPI hardware manipulation was being done before entering the semaphore-
protected critical section. The fix is to reorder the code: first obtain
the semaphore, then do everything else.
* In the corner case of L1/DSP recovery, l1_abb_power_on() would call some
non-semaphore-protected ABB & SPI init functions. The fix is to skip those
calls in the case of recovery.
* A few additional corner cases existed, all of which are fixed by making
ABB semaphore protection 100% consistent for all ABB functions and code paths.
There is still one remaining problem of priority inversion: suppose a low-
priority task calls an ABB function, and some medium-priority task just happens
to preempt right in the middle of that semaphore-protected ABB operation. Then
the high-priority SPI task is locked out for a non-deterministic time until
that medium-priority task finishes its work and goes back to sleep. This
priority inversion problem remains outstanding for now.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 26 Apr 2021 20:55:25 +0000 |
parents | 62480f597962 |
children |
line wrap: on
line source
#ifndef _DEF_MMI_SMSSEND_H_ #define _DEF_MMI_SMSSEND_H_ #undef GLOBAL_EXT #if defined (MMI_SMSREAD_C) #define GLOBAL_EXT #else #define GLOBAL_EXT extern #endif /******************************************************************************* CONDAT (UK) ******************************************************************************** This software product is the property of Condat (UK) Ltd and may not be disclosed to any third party without the express permission of the owner. ******************************************************************************** $Project name: Basic MMI $Project code: BMI (6349) $Module: SMS $File: mmismssend.h $Revision: 1.0 $Author: Condat(UK) $Date: 25/10/00 ******************************************************************************** Description: header of template for MMI yyy dynamic event handling ******************************************************************************** $History: mmismssend.h Feb 02, 2005 REF: CRR 28479 xnkulkar Bug: While saving a SMS, if the user presses LSK while the 'Saved' dialog is displayed, the 'Saved' dialog doesn't get dismissed. Solution: Only RSK and Hangup keys dismiss the 'Saved' info screen and all other key presses are ignored. 25/10/00 Original Condat(UK) BMI version. $End *******************************************************************************/ /******************************************************************************* Include Files *******************************************************************************/ #include "mfw_mfw.h" /* SPR#1428 - SH - New Editor changes */ #ifndef NEW_EDITOR #include "mmiEditor.h" //GW Added for T_EDITOR structure #endif /******************************************************************************* Shared Structure Definitions *******************************************************************************/ typedef struct { /* administrative data */ T_MMI_CONTROL mmi_control; T_MFW_HND win; T_MFW_HND parent; T_MFW_HND child_dialog;/* to keep the window of dialog */ T_MFW_HND sms_handler; SHORT id; T_SmsUserData edt_data; /* pointer of text and number */ T_MFW_HND text_editor; T_MFW_HND number_editor; T_MFW_HND sc_number_editor; T_MFW_HND options_win; } T_SEND; typedef enum { /* Logical frames */ SEND_ID, SAVE_ID, /* Extern windows */ PHBK_ID, /* Editor windows */ SMSSEND_ID_TEXTEDIT, SMSSEND_ID_NBEDIT, SMSSEND_ID_CENTREEDIT, SMSSEND_ID_CENTREEDIT_CHANGE, /* Dialog windows */ SMSSEND_ID_WAITING, SMSSEND_ID_WAIT_SEND, SMSSEND_ID_SENT, SMSSEND_ID_NOT_SENT, SMSSEND_ID_WAIT_SAVE, SMSSEND_ID_SAVED, SMSSEND_ID_NOT_SAVED, SMSSEND_ID_LIST_FULL, SMSSEND_ID_SAVE_NOT_READY, //PATCH TB SMSSEND_ID_SC_NOT_READY, //PATCH TB SMSSEND_ID_NOT_ALLOWED } sms_send_id; /******************************************************************************* Function Prototypes *******************************************************************************/ GLOBAL_EXT T_MFW_HND SmsSend_SEND_start(T_MFW_HND parent_window, T_SmsUserData *UserData); GLOBAL_EXT T_MFW_HND SmsSend_SAVE_start(T_MFW_HND parent_window, T_SmsUserData *UserData); GLOBAL_EXT T_MFW_HND V_start(T_MFW_HND parent_window, MfwMnuAttr *menuAttr); GLOBAL_EXT int M_callVoice(MfwMnu* m, MfwMnuItem* i); // Feb 02, 2005 REF: CRR 28479 xnkulkar // Prototype of function mmi_dialog_information_screen_save_sms() T_MFW_HND mmi_dialog_information_screen_save_sms(T_MFW_HND parent_win, int TxtId, char* text, T_VOID_FUNC call_back, USHORT identifier); int SmsSend_R_OPTExeCentreEdit(MfwMnu* m, MfwMnuItem* i); // Used im mmismsread to compare with SMS center number GLOBAL_EXT UBYTE SmsSend_get_config_data(T_MFW_SMS_INFO *config_data); GLOBAL_EXT void SmsSend_convert_to_inter(T_MFW_SMS_ADDR *source_number, char *dest_number); UBYTE SmsSend_set_SrvCntr_number (T_MFW_SMS_INFO *config_data); /* SPR#1428 - SH - New Editor: no longer required */ #ifndef NEW_EDITOR //GW 29/11/01 - Added void SmsSend_loadEditDefault(T_EDITOR_DATA * edit_info); #endif /* NEW_EDITOR */ #endif /* _DEF_MMI_SMSSEND_H_ */