FreeCalypso > hg > fc-tourmaline
view src/condat/com/include/cl_shrd.h @ 51:04aaa5622fa7
disable deep sleep when Iota LEDB is on
TI's Iota chip docs say that CLK13M must be running in order for
LEDB to work, and practical experience on Mot C139 which uses
Iota LEDB for its keypad backlight concurs: if Calypso enters
deep sleep while the keypad backlight is turned on, the light
flickers visibly as the chipset goes into and out of deep sleep.
TI's original L1 sleep manager code had logic to disable deep sleep
when LT_Status() returns nonzero, but that function only works
for B-Sample and C-Sample LT, always returns 0 on BOARD 41 - no
check of Iota LEDB status anywhere. Change this code for our
current hardware: disable deep sleep when Iota LEDB has been
turned on through LLS.
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Mon, 19 Oct 2020 05:11:29 +0000 |
| parents | 4e78acac3d88 |
| children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | Project : COMLIB | Modul : cl_shrd +----------------------------------------------------------------------------- | Copyright 2002 Texas Instruments Berlin, AG | All rights reserved. | | This file is confidential and a trade secret of Texas | Instruments Berlin, AG | The receipt of or possession of this file does not convey | any rights to reproduce or disclose its contents or to | manufacture, use, or sell anything it may describe, in | whole, or in part, without the specific written consent of | Texas Instruments Berlin, AG. +----------------------------------------------------------------------------- | Purpose : Definitions of global types used by common library functions | and the prototypes of those functions. +----------------------------------------------------------------------------- */ /* * Version 1.0 */ /**********************************************************************************/ #ifndef CL_SHRD_H #define CL_SHRD_H #ifdef TI_PS_FF_AT_P_CMD_CTREG #define MAX_CTREG_TAB_LEN 25 #endif /* TI_PS_FF_AT_P_CMD_CTREG */ /* ME STATUS for Timing advance structure */ #define ME_STATUS_IDLE 0 #define ME_STATUS_NOT_IDLE 1 /*====STRUCTURE DEFINITION=========================================*/ typedef struct { UBYTE service_mode; U16 lac; U8 mcc [3]; U8 mnc [3]; USHORT cell_id; }T_LOC_INFO; typedef struct { UBYTE me_status; UBYTE tm_adv; }T_TIM_ADV; #ifdef TI_PS_FF_AT_P_CMD_CTREG typedef enum { MODE_NotPresent = 0, TREG_READ_MODE, TREG_WRITE_MODE }T_TREG_MODE; typedef enum { MODE_TIME_NotPresent = 0, NOSERVICE_MODE_TIME, LIMSERVICE_MODE_TIME }T_TREG_TABLE; typedef struct { T_TREG_MODE mode; T_TREG_TABLE tab_id; UBYTE tab_val[25]; }T_TREG; #endif /* TI_PS_FF_AT_P_CMD_CTREG */ typedef struct { T_LOC_INFO location_info; T_TIM_ADV timing_advance; #ifdef TI_PS_FF_AT_P_CMD_CTREG UBYTE no_serv_mod_time[25]; UBYTE lim_serv_mod_time[25]; #endif /* TI_PS_FF_AT_P_CMD_CTREG */ }T_SHRD_DATA; EXTERN T_SHRD_DATA *shared_data; #ifdef TI_PS_FF_AT_P_CMD_CTREG EXTERN const UBYTE no_service_mode_time[25]; EXTERN const UBYTE lim_service_mode_time[25]; #endif /* TI_PS_FF_AT_P_CMD_CTREG */ /*=================================================================*/ /*====FUNCTION PROTOTYPE===========================================*/ EXTERN void cl_shrd_init (T_HANDLE handle); EXTERN void cl_shrd_exit (void); EXTERN BOOL cl_shrd_get_loc (T_LOC_INFO *loc_info); EXTERN void cl_shrd_set_loc (T_LOC_INFO *loc_info); EXTERN BOOL cl_shrd_get_tim_adv(T_TIM_ADV *tim_adv); EXTERN void cl_shrd_set_tim_adv(T_TIM_ADV *tim_adv); #ifdef TI_PS_FF_AT_P_CMD_CTREG EXTERN BOOL cl_shrd_set_treg_val(T_TREG *treg); EXTERN BOOL cl_shrd_get_treg_val(T_TREG *treg); EXTERN BOOL cl_shrd_get_treg (UBYTE tab_id, UBYTE offset, UBYTE *tab_val); #endif /* TI_PS_FF_AT_P_CMD_CTREG */ /*=================================================================*/ #endif /* CL_SHRD_H */
