view src/g23m-gprs/grlc/grlc_ruf.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 fa8dc04885d8
children
line wrap: on
line source

/* 
+----------------------------------------------------------------------------- 
|  Project :  GPRS (8441)
|  Modul   :  GRLC
+----------------------------------------------------------------------------- 
|  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 for service RU.
+----------------------------------------------------------------------------- 
*/ 

#ifndef GRLC_RUF_H
#define GRLC_RUF_H




EXTERN  void   ru_init ( void );

EXTERN  void   ru_get_next_sdu ( void );

EXTERN  USHORT ru_calc_rlc_data_size ( T_CODING_SCHEME  cs_type_i, UBYTE ti_bit_i );

EXTERN  USHORT ru_set_block_status ( T_CODING_SCHEME  cs_type_i );

EXTERN T_CODING_SCHEME  ru_get_cs_type ( USHORT  bs_i );

EXTERN  void   ru_tbf_init ( void );

EXTERN  void   ru_send_mac_data_req ( UBYTE bsn_i );

EXTERN  void   ru_set_prim_queue ( BOOL cd_state_i );

EXTERN  UBYTE  ru_countdown_procedure ( UBYTE ret_blocks );

EXTERN  void   ru_update_vb ( void );

EXTERN  void   ru_calc_rlc_data_block ( UBYTE bsn_i );

EXTERN  void   ru_handle_n3102 ( T_PAN_CNT  pan_cnt_i );

EXTERN  UBYTE  ru_calc_va ( void );

EXTERN  void   ru_ret_bsn ( void );

EXTERN  void   ru_change_of_cs ( T_CODING_SCHEME  cs_type_i );

EXTERN  USHORT ru_recalc_rlc_oct_cnt ( void );

EXTERN  BOOL   ru_contention_resolution ( void );

EXTERN  void   ru_delete_prims ( UBYTE last_bsn_i );

EXTERN  BOOL   ru_handle_n3104 ( void );

EXTERN void    ru_send_control_block ( void );

EXTERN void    ru_stall_ind ( void );

EXTERN void    ru_new_data ( void );

EXTERN BOOL    ru_within_window ( UBYTE bsn_i, UBYTE high_value_i,UBYTE low_value_i );

EXTERN void    ru_check_pl_ret ( UBYTE rlc_blocks_sent_i );

EXTERN void    ru_set_T3198 ( UBYTE bsn_i );

EXTERN void    ru_send_ul_dummy_block ( void );

EXTERN void    ru_handle_stall_ind ( void );

EXTERN void    ru_reorg_l1 ( UBYTE sent_blks_i );

EXTERN void    ru_del_prim_in_uack_mode (UBYTE rlc_blocks_sent_i);

EXTERN void    ru_handle_timers ( UBYTE rlc_blocks_sent_i);

EXTERN UBYTE   ru_set_next_bsn_ret ( void);

EXTERN void    ru_handle_nts (UBYTE rlc_blocks_sent_i);

EXTERN void    ru_handle_tbf_start_in_ptm ( UBYTE rlc_blocks_sent_i );

EXTERN void    ru_switch_ul_buffer  ( UBYTE rlc_blocks_sent_i );

EXTERN void ru_cgrlc_st_time_ind  ( void );

EXTERN BOOL ru_ctrl_blk_selection_allowed();

EXTERN BOOL ru_peek_next_sdu(USHORT *sdu_len,UBYTE *active_prim,UBYTE *next_prim);

EXTERN UBYTE ru_peek_for_ctrl_blk();

#endif /* !GRLC_RUF_H */